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ABSTRACT 


A relational database management system (RDBMS) is a software product that 
structures data in accordance with the relational data model and permits data 
manipulation based on relational algebra. There are two widely-used query languages for 
the relational database management systems (RDBMS’s). These are Structured Query 
Language (SQL) and Query By Example (QBE). Although these languages are powerful, 
they both have drawbacks concerning ease-of-use, especially in expressing universal 
quantification and specifying complex nested queries. 

In order to eliminate these problems, Data Flow Query Language (DFQL) has 
been proposed. DFQL offers an easy-to-use graphical user interface to the relational 
model based on a data flow diagram, while maintaining all of the strengths of SQL and 
QBE. 

The purpose of this thesis is to implement DFQL, allowing the users to login one 
or more relational database(s) through JDBC, view the structure of the connected 
databases graphically, and implement inquiries in SQL and DFQL to retrieve the data 
from the database(s). 
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I. INTRODUCTION 


A. OVERVIEW 

A relational database management system (RDBMS) is a software product that 
structures data in accordance with the relational data model and permits data 
manipulation based on relational algebra. There are two widely-used query languages for 
the relational database management systems (RDBMS’s). These are Structured Query 
Language (SQL) and Query By Example (QBE). Although these languages are powerful, 
they both have drawbacks concerning ease-of-use, especially in expressing universal 
quantification and specifying complex nested queries. 

In order to eliminate these problems. Data Flow Query Language (DFQL) has 
been proposed. DFQL offers an easy-to-use graphical user interface to the relational 
model based on a data flow diagram, while maintaining all of the strengths of SQL and 
QBE. 

The purpose of this thesis is to implement DFQL, allowing the users to login one 
or more relational database(s) through Java Database Connectivity (JDBC), view the 
structure of the connected databases graphically, and implement inquiries in SQL and 
DFQL to retrieve the data from the database(s). 

B. BACKGROUND 

Relational Database technology was first described in 1970 by Ted Codd. His 
description of a database management system based on “relational” principles quickly 
turned from theory to real products which are known as Relational Database Management 
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Systems (RDBMS’s). The most common query languages used to implement RDBMS 
products are Structured Query Language (SQL) and Query By Example (QBE). 

The Structured Query Language (SQL) is a text-based language for accessing data 
in a relational database. Originally created by IBM in 1974, many vendors developed 
dialects of SQL. In the early 1980's, the American National Standards Institute (ANSI) 
began developing a relational database language standard. ANSI and the International 
Standards Organization (ISO) published SQL standards in 1986 and 1987, respectively 
[Ref.7;p.3]. 

On the other hand. Query By Example (QBE) is a visual-oriented language for 
accessing data in a relational database. QBE was developed by Zloof (1977) at IBM 
laboratories. Today, QBE is the best known and most widely-used visual RDBMS 
programming language [Ref.l:p.324]. 

Neither SQL nor QBE have succeeded in addressing the problems concerning 
ease-of-use issues, expecially in expressing universal quantification, specifying complex 
nested queries, flexibility and consistency in specifying queries with respect to data 
retrieval. 

In order to alleviate these problems, a new visual-oriented language. Data Flow 
Query Language (DFQL) has been proposed. DFQL was first introduced in a research 
article entitled, “DFQL: Dataflow Query Language for Relational Databases” by Gard J. 
Clark, C. Thomas Wu, Naval Postgraduate School, Department of Computer Science. 

Data Flow Query Language offers a graphical/visual interface to the relational 
model based on a data flow paradigm. DFQL retains all of the power of current query 
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languages, and is equipped with an easy to use facility for extending the language with 
advanced operators, thus providing query facilities beyond the benchmark of first-order 
predicate logic [Ref.2:p.l3]. 


C. CHAPTER SUMMARY 

Chapter n presents a description of the Relational Model concept, SQL, QBE, and 
DFQL. The chapter also discusses the problems faced by SQL mid QBE, and brings up 
DFQL solutions to these problems. 

Chapter HI presents the structure of our DFQL implementation. The chapter gives 
detailed information about the applications Database and Graphical User Interface. 

Chapter IV specifies the system requirements and design details. This chapter also 
includes a user manual that shows the usage of all the features of the application and 
explains the purpose/function of them. 

Chapter V offers conclusions about this work and recommendations for future 

work. 
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n. RELATIONAL MODEL AND QUERY LANGUAGES 

This chapter presents the relational model concept and the query languages used 
for the relational model. In order to understand why there is a need for a Data Flow 
Query Language, we need to study the relational model concept, analyze the other query 
languages, and identify the problems with them which can be mitigated through the use 
ofDFQL. 

The query languages for the relational database models can be classified as text- 
based query languages and visual-based query languages. Text-based query language part 
focuses on the Stractured Query Language (SQL), while the visual-based query 
languages part focuses on Query By Example (QBE) and Data Flow Query Language 
(DFQL). 

A. THE RELATIONAL MODEL 

The Relational Model is very simple and elegant; a database is a collection of one 
or more relations, where each relation is a table with rows and columns. This simple 
tabular representation enables even novice users to understand the contents of a database, 
and permits the use of simple, high-level languages to query the data. The major 
advantages of the relational model over the older data models are its simple data 
representation and the ease with which even complex queries can be expressed 
[Ref.5:p.51]. 

The relational database model gives us the luxury of forgetting the actual physical 
data storage characteristics, thereby allowing us to concentrate on the logical view of the 
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database. That is, we may focus on the human perception of data storage rather than on 
the often difficult-to-comprehend manner in which the computer sees those same data 
Since the relational model achieves both data independence and stractural 
independence, it becomes much easier to design the database and to manage its contents. 

One of the reasons for the relational database model's rise to dominance in the 
database market is its veiy powerful and flexible query capability. [Ref.6:p.l32]. 


B. TEXT-BASED QUERY LANGUAGES 

Text-based query languages can be divided into three types: languages based on 
relational calculus, those based on relational algebra, and a combination of these two, 
which is SQL. 

In relational calculus, a query describes the desired answer without specifying 
how the answer is to be computed. This non-procedural style of querying is called 
declarative. Queries in relational algebra are composed using a collection of operators, 
and each query describes a step-by-step procedure for computing the desired answer, 
(i.e., queries are specified in an operational manner.). 

1. Structured Query Language (SQL) 

The primary vehicle used for querying, reading, and updating relational databases 
is a language called Structured Query Language, or SQL (generally pronounced sequel). 
SQL is implemented as a mixture of both relational algebra and relational calculus by 
including the nesting capability and block stracture feature. 

Stmctured Query Language (SQL) is the most widely used commercial relational 

database language. SQL was originally developed at IBM in the SEQUEL-XRM and 
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System-R projects (1974-1977). Almost immediately, other vendors introduced DBMS 
products based on SQL, and is now a de facto standard. SQL continues to evolve in 
response to changing needs in the database arena. Although the new standard for SQL 
has recently been released (SQL-3), the most commonly used standard is still SQL-92. 

SQL allows users to access data in relational database management systems, such 
as Oracle, Sybase, Informix, Microsoft SQL Server, Access, and others by allowing users 
to describe the data the user wishes to see. SQL also allows users to define the data 
(DDL) in a database, and manipulate that data (DML). 
a. Strengths of SQL 

The strengths of SQL provide benefits for all types of users, including 
application programmers, database administrators, managers, and end users. Technically 
speaking, SQL is a data sublanguage. Among features are the following: 

> Processes sets of data as groups rather than as individual units. 

> Provides automatic navigation to the data. 

> Uses statements that are complex and powerful individually. 

> Essentially, SQL lets you work with data at the level of logic. You need to 
be concerned with the implementation details only when you want to 
manipulate the data. 

SQL provides statements for a variety of tasks, including: 

> Querying data 

> Inserting, updating, and deleting rows in a table 

> Creating, replacing, altering, and dropping objects 
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^ Controlling access to the database and its objects 

^ Guaranteeing database consistency and integrity 

All major relational database management systems support SQL, so users 
can transfer all skills gained while using SQL from one database to another. In addition, 
all programs written in SQL are portable. They can often be moved from one database to 
another with veiy little modification. 

b. Weaknesses of SQL 

• Difficulty in comprehending SQL: SQL is primarily a declarative query 
language. It is very easy to express simple queries, but when it comes to 
more complex queries, the logical expression can become complicated. 
The lack of procedural nature of SQL is compensated by embedding it into 
a procedural, thireSrd generation host programming language [Ref.2:p.3]. 

• Difficulty in expressing Universal Quantification: The idea of universal 

quantification is expressed in English by the phrase “For All.” There is no 
specific “For All” operator in SQL. This forces one to use “negative logic” 
(the Existential quantifier, NOT EXISTS to achieve the result of universal 
quantification) [Ref.2:p.3]. 

• Lack of orthogonality: SQL does not present a simple, clean, and 
consistent structure to the users. There are numerous examples of arbitrary 
restrictions, exceptions, and special rules. Lack of orthogonality increases 
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the number of special rules to be memorized by the user, decreases its 
readability, and in general decreases the usability [Ref.2:p.4]. 

• Unnecessary complexity due to nesting construct: SQL permits a 
nesting stracture, which allows the specification of certain types of 
queries. These nesting stractures are very hard to counstruct, and they 
increase the complexity of the expressions [Ref.2;p.4]. 

• Lack of functional notation: The use of functions in programming 
languages allows the abstraction of operational detail to whatever level is 
appropriate. Complex queries that provide an intermediate result for a 
higher level query could hide this result from the user through the use of 
functional notation. This concept is universally adopted in all modem 
programming languages, but not in SQL [Ref.2:p.4]. 

C. VISUAL-BASED QUERY LANGUAGES 

Visual-based Query Languages are also used for querying relational data. These 
languages are different from text based query languages in that visual-based languages 
have a graphical user interface that allows users to constract queries. To define a query in 
the conventional database query language, a user must be familiar with the logical design 
of the database and the query language. With the recent advances in graphical user 
interfaces (GUI), visual query languages have been proposed to ease the user's burden in 
constmcting a query. 
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The most important reason for having a visual query language for a scientific 
database application is to provide a simple yet integrated environment for data retrieval 
and visualization. 

QBE and DFQL are examples of such visual query languages. They provide a 
graphical environment through which users constract queries and see the results. They 
are conceptually simple, expressive and helpful to user. 

1. Query by Example (QBE) 

Query By Example (QBE) was developed approximately at the same time as SQL 
during the 1970’s at IBM’s Laboratory Research Center [Ref.l:p.325]. QBE is another 
language for querying (and, like SQL, for creating and modifying) relational data. QBE is 
different from SQL and from most other database query languages in that QBE have a 
graphical user interface that allows users to write queries by creating sample tables on the 
screen. A user needs minimal information to get started, and the whole language contains 
relatively few concepts. QBE is especially suited for queries that are not too complex 
which can be expressed in a few tables. 

a. Strengths of QBE 

QBE is a very user-friendly query language with a graphical interface. 
This language provides a pictorial representation of database tables. Symbols placed in 
the proper table columns specify query selection conditions, grouping, data display, and 
database updates. 

QBE is very intuitive, even for novice users. QBE allows the relatively 
inexperienced users to get started in specifying simple queries, even if they have no prior 
knowledge of programming languages. 
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b. Weaknesses of QBE 

Although a very powerful tool for simple queries, QBE becomes less and 
less useful as the complexity of the queries increases, and its use presents problems with 
more complex queries [Ref.4:p.526]. 

QBE is relationally incomplete, since it does not provide support for 
universal or existential quantification. The queries which involve universal quantification 
can’t be specified. [Ref.4:p.570] 

2. Data Flow Query Language (DFQL) 

DFQL is a visual relational algebra for the manipulation of relational databases. 
DFQL has sufficient expressive power and functionality to allow the user to express 
database queries. 

Three principles guided our design of DFQL: conceptual simplicity, 
expressiveness, and provision of user assistance. 

Because this language is targeted for users who are not programmers, DFQL 
should be conceptually simple. To achieve conceptual simplicity, the developed product 
focuses on the adoption of a functional orientation, maintaining compatibility with the 
relational data model and query operations, and use of understandable, explicitly stated 
operations in a query. 

Since queries to a relational database are unconstrained in their form, our query 

language must be powerful enough to represent all queries a user may need. DFQL 

implements all the basic operators of relational algebra, and is therefore relational- 

complete. DFQL provides all of SQL's data retrieval capabilities as defined by the SQL 
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SELECT statement. DFQL also allows the user to define new operators in terms of 
external programs, and to integrate them into the language as new operators on data 
tables. 

User assistance implies more than on-line documentation. A query should be 
visualized graphically, and assistance for query construction and troubleshooting and 
context-sensitive help should also be provided. 

The operation logic of FDFQL is very simple. Data flows from one or more 
source relations to the flnal result relation through one or more intermediate operators. 
The result is constructed in the order specified by the directed acyclic graph. Every 
operator has one or more input ports and one output port. An arc can be attached to an 
operator only at these ports. An input port can only receive one arc. On the other hand 
there is no limit on the number of arcs that may emanate from an output port; each 
outgoing arc simply duplicates the output of the operator. 


Operator Body 

^ 7 

O O 

Input Nodes 


—► 

1 



J 


Output Node 


Figure 2.1: Operator Construction 


A source relation in DFQL retrieves a user-specified relation from the underlying 
database. 

The result relation may be thought of as a receptor for all the data that flow down 
from the sources of the graph. It provides a simple, plain text rendition of the Hata it 
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receives. The result relation of each operator can be displayed to view the partial results 
without affecting the semantics of the graph being constructed. 

An operator receives one or more relations from its input arcs, processes them to 
produce a new relation, and then passes out the new relation. How the input relations are 
processed depends on the particular operator. 

All operators of DFQL implement operational closure: output from each operator 
is always a relation. Two broad categories of DFQL operators are defined. A primitive 
operator has been defined directly in the native DFQL language. They are basic, non- 
basic (advanced) and display operators. A user-defined operator has been constmcted by 
the user from primitives and possibly other previously created user-defined operators 
[Ref.2:p.6]. 

(1) Basic DFQL Operators: DFQL provides six basic operators derived from 
the requirements for relational completeness as well as form of grouping or aggregration. 
A query language that is complete has the expressive power of first-order predicate 
calculus. Five relational operations must be implemented: selection, projection, union, 
difference, and Cartesian product (join). Provision is also made for simple aggregation 
by including groupcnt (group count). 
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TABLE 2.1: Basic DFQL Operators 


DFQL Operator 

SQL Equivalent 

Relation 

HI 

■■ 

Condition 

SELECT DISTINCT* 

FROM relation 

WHERE condition 



SELECT DISTINCT 
attribute list 
FROM relation 




SELECT DISTINCT * 
FROM relationl 
MINUS 

SELECT DISTINCT * 
FROM relation! 


DIFFERENCE 

Relationl Relation! SELECT DISTINCT * 



FROM relationl 
UNION 

SELECT DISTINCT * 
FROM relation! 


UNION 
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Grouping Count 
Relation attributes attributes 

SELECT DISTINCT 
grouping attributes, 

COUNT(*) count attributes 

FROM relation 

GROUP BY grouping attributes 

groupcnt 


O 

GROUP CNT 




(2) Non-basic (Advanced) DFQL Operators: DFQL provides several other 
primitive operators to perform special low-level operations on relations. All of these 
primitive operators can be specified as user-defined operators. 

TABLE 2.2: Advanced DFQL Operators 


DFQL Operator SQL Equivalent 


Relationl Relation2 Join attribute list I SELECT DISTINCT * 

FROM relationl rl, relation2 r2 
WHERE rl.attribute = r2.attribute 



EQJOIN 


Grouping 

Relation attributes Condition 


SELECT DISTINCT 
grouping attribute 
FROM relation 
WHERE condition 
GROUP BY grouping attribute 


GROUP ALL SATISFY 













Grouping 

Relation attributes Condition Number 



GROUP N SATISFY 


Relationl Relation2 



SELECT DISTINCT 
grouping attribute 
FROM relation 
WHERE condition 
GROUP BY grouping attribute 
HAVING COUNT (*) number 


SELECT DISTINCT * 
FROM relationl 
INTERSECT 
SELECT DISTINCT* 
FROM relationl 


INTERSECT 


Grouping Aggregate 
Relation attributes attributes 



GROUP MIN 


Grouping Aggregate 
Relation attributes attributes 



SELECT DISTINCT 
Grouping attributes, 

MIN (aggregate attributes) 
FROM relation 
GROUPBY 
Grouping attributes 


SELECT DISTINCT 
Grouping attributes, 

MAX (aggregate attributes) 
FROM relation 
GROUPBY 
Grouping attributes 


GROUP MAX 


Grouping Aggregate 
Relation attributes attributes 



SELECT DISTINCT 
Grouping attributes, 

AVG (aggregate attributes) 
FROM relation 
GROUPBY 
Grouping attributes 


GROUP AVG 











(3) Display Operators: The display operators are provided to allow the user to 
print the contents of a relation on the computer screen. The proposed implementation 
does not use display operators. Instead, one more control has been added to the operators. 
The default value for this control is no display. Checking this control displays the result 
of the respective operator. 

(4) User-defined DFQL Operators: These types of operators provide the user 
with the flexibility to define his own style of the operators, and extend the capability of 
the language according to his desires. With user-defined operators, user can construct his 
own operators that look and behave like the primitive operators provided in DFQL. 
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m. APPLICATION STRUCTURE 


In this chapter, the structure of the overall application will be examined. There are 
two main parts in the implementation of DFQL, the Database and the Graphical User 
Interface. 


A. DATABASE 

This part of the application manages the connection with a JDBC database. There 
are five classes in the Database: Database, Databasehifo, Table, Attribute, and Relation 
classes. 

The Database class is the interface between the graphical user interface and the 
JDBC database. This class holds all the data about the connected database. This data 
includes table data, connection information (database URL, driver name, user name, and 
password), database metadata, and tree structure of the database. The queries are 
executed through this class. 

This class also has the capability to store all the queries executed in the current 
session and their results. The user can choose to store the queries and their results in the 
programs memory for future use. If a queiy is executed in the current session, this class 
does not send the query to the JDBC database but rather returns the result from the 
memory. Since the JDBC database can be manipulated by another source during the 
session, the application enables the user to oblige this class to send the query to the JDBC 
database. 
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The Databaselhfo class holds the connection information. The driver name, 
database URL, user name and password data are held in this class. An instance of this 
class is a data member of the database object. 

The Table class holds both the metadata and data of a relation. The information 
which can be stored in this class includes: the attribute information of a relation; the SQL 
query to get the relation; the relation name; and the user data. The relation can be a user 
defined relation of the JDBC database, or a resulting relation of a query. 

The Attribute class holds the metadata of an attribute in a relation. This metadata 
contains the name, the data type, the size, the nullability, and the case sensitivity of an 
attribute. 

The Relation class implements a JTable model in order to display the relation data 
on the screen. 

B. GRAPHICAL USER INTERFACE 

As previously mentioned, this language is targeted for non-programmer users; 
thus, the simplicity of the program is a very important factor. In order to ensure its 
simplicity, the graphical user interface (GUI) is designed to be very user friendly. GUI 
contains one main screen which allows the user to access every feature of the program as 
well as other screens for secondary operations, such as save/open file or print. 

1. Main Screen 

The main screen is the first screen displayed when the user runs the program. All 
the activities will occur on this screen. This screen contains a pull down menu, a toolbar, 
two scroll panels, two tabbed panels and two buttons. All of the main screen’s features 
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buttons, tabs, etc.) are in a disabled mode at the beginning, hi order to enable them, the 
ser first needs to connect a database. The logon screen, which will be described later, is 


sed to make the database connections. 


Pull down Menu : File, Connection, SQL, DFQL, Help 


7 


Tabbed Panel, 
Main Panel 


^No Current Database Connectiot 












ToolBar 


Scroll Panel, 
Meta Panel 


Scroll Panel, 
Results Panel 


Buttons, 

Multi Operator 
Multi Database 


Figure 3.1: Main Screen 


Pull Down Menu 

• File: The file tab has two-sub menus. Exit, which terminates the program, 
and Print, which displays the print screen and allows user to print the 


results of queries. 
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• Connection: The connection tab has three sub-menus, Connect (displays 
the logon screen), Disconnect (both are used to make database 
connections) and Settings, which displays the settings screen and allows 
the user to arrange the connection settings. 

• SQL: The SQL tab has only one sub-menu. Execute, which is used to 
execute the regular SQL query. 

• DFQL: The DFQL tab has four sub-menus. New, Save, Load and 
Execute. New is used to clean all the previous DFQL work and prepare the 
program to create a new query. Save and Load are used to save a created 
DFQL query and reuse this query. Execute is used to run a DFQL query. 

• Help: The help tab has only one sub-menu. Manual, which displays the 
user manual for this program. 

ToolBar 

The toolbar has eleven buttons. These buttons are: Exit, Print, Connect, 
Disconnect, SQL Execute, New, Save, Load, DFQL Execute, Manual and Multiple 
database connection. The purpose of these buttons is to provide fast access to the menu 
items, except the last one, database connection. This button is used to send the query to 
every database connected. 

Panel Meta 

This scroll panel is used to display a database’s meta data tree. Panel holds a tree 
called a Meta tree. The root of this tree is a string, “Database URLs.” Every database 
connected is added to this root. Each database has its relations, and each relation has its 
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attributes as nodes. When the user disconnects a database, the related leaf of the tree is 


deleted. 

Panel Results 

This scroll panel is used to display the results of the executed query. 

Buttons 

There are two buttons on the main screen. These are Display Operator and 
Display Database. The Display operator button is used to display the result of the query, 
which is produced by the operator, whose display option is checked. Every time the user 
presses this button, the next operators query result is displayed. The Display Database 
button is used to send the same query to the next database connected. 

Let us assume we have a DFQL query with two operators, and both of their 
display options are checked while connected to two databases at that moment. When the 
user presses the DFQL Exeute button, the first operator’s query is sent to the first 
database connected. Then, the user presses the display operator button to see the result of 
the next operator. After that, the user presses the display database button to see the result 
of the first operator using the second database. And by pressing the display operator 
button, the second operator’s query is sent to the second database. 

Panel Main 

This is a tabbed panel with four tab options. These are: Data, Definition, DFQL 
and SQL. 

The data tab is used to display the content of the selected relation. When the user 
clicks on a relation with the left mouse button, this tab automatically becomes active and 
displays the data, which is held by this relation. 
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The definition tab is used to display detailed information about the database tree. 
This tab displays the properties of the selected item from the tree. 

The SQL tab is basically a text editor which allows the user to enter a regular 
SQL query. This tab also displays the SQL query equivalent of the graphical DFQL 
query when one has been created. 

The DFQL tab is a canvas which allows the user to create a DFQL query by using 
the built-in or user-defined operators. When this tab is selected, another tabbed panel is 
displayed automatically. This panel is called the Operator’s Panel, and has three tabs. 
These are: Basic, Advanced and User Defined. 



Figure 3.2: DFQL Panel and Operator Panel 
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2. Logon Screen 

This screen allows the user to enter the connection information (User name, 
Password, Database URL and Database Driver), in order to log onto the target database. 



Figure 3.3: Logon Screen 

3. Message Screen 

This screen is used to display system messages, such as connection information or 
error messages. 



Figure 3.4: Message Screen 

4. Print Screen 

This screen allows the user to print out the results of the executed query. 
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Statusc:;- Ddauk printer; Ready 
Tipa: WinFax 
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Figure 3.6: Open and Save File Screens 


Figure 3.5: Print Screen 
5. Open/Save File Screen 

This screen has two purposes. One is to save and load the previously created 
queries, and the second is to save and load user defined operators. Saved query files have 
an extension “dfql,” and user defined operators have an extension “uso.” 
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6 . 


User Manual Screen 


This screen displays the user manual for this program. The user manual is a text 
file called “Manual.txt.” 



Figure 3.7: User Manual Screen 
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IV. IMPLEMENTATION OF APPLICATION 


This chapter specifies the both hardware and software requirements for this 
application. It also gives the user more information about the design details. This chapter 
also includes a user manual that shows the usage of all the features of the application and 
explains the purpose/function of them. 

A. HARDWARE REQUIREMENTS 

• Intel Pentium/166MHz or compatible 

• Microsoft Windows 95/98 or NT 4.0 

(SP3 or higher)(ODBC driver properly installed) 

• 64Mb RAM (96Mb or higher recommended) 

• 100Mb hard disk space 

• SVGA or higher resolution (800x600 256 color) 

• Mouse or other pointing device 

B. SOFTWARE REQUIREMENTS 

• Borland JBuilder 3.0 

• Microsoft access 2000 or Oracle Relational Database Management System 
(Personal Oracle 8.x for windows98/NT) 

C. SYSTEM SUMMARY 

1. The user needs to provide database connection information to connect to 
any database. This information consists of the user’s name, password, target database’s 
URL and driver information. 
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2. After the connection has been successfully established, the connected 
database’s meta data is displayed on the screen. This meta data consists of the names and 
the properties of the database, relations and relation attributes. Additionally, the content 
(data) of the relations is also displayed on the screen. 

3. The user can concurrently connect to as many databases as desired. The 
last connected database is currently active, and the displayed Meta data belongs to this 
database. The user can change the active database by selecting the desired database. 

4. The application has a text editor which allows the user to enter and 
execute a regular SQL statement. The result of this execution is also displayed on the 
screen. 

5. The user also can use DFQL operators to produce the data flow diagram 
graphically. The diagram automatically produces a query. This query is executed, and the 
result of this query is displayed on the screen. 

6. Both SQL and DFQL queries can be executed for all the databases 
connected. The results are displayed in the order in which they were connected. 

D. EXECUTION OF APPLICATION 

1. Database Logon 

In order to start using the program, the user must connect a database. The 
database connection can be done via a logon screen. The user can get the logon screen by 
pressing the connect button, or by selecting the connect menu item under the database 
menu. When the logon screen is displayed, the user needs to provide the following 
information for the desired database. 
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Enter connection information 


HiaigS 


User Mame: 
Password: 


|anonymous| 


[guest 


Database : | jdbc:odbc:studentdb1 
; Driver: 


• ijsunJdbc.odbc.JdbcOdbcDriver 


Cancel 


j c; 


OK 


Figure 4.1: Database Logon 

2. Multiple Database Connection 

By using the same connection screen, the user can connect to as many databases 
as desired. Each connected database is added to the Meta data tree. The most recently 
connected database is assumed to be automatically active. The user can change the active 
database by selecting the database name from the database’s Meta data tree. 

3. Meta Data Tree 

When the connection is completed, the database metadata is displayed on the 
screen. The left part of the screen displays the general database tree. The nodes under the 
database name are the relations of the database. The nodes under the relation nodes 
happen to be the attributes of the related relation. In order to obtain information about an 
item, the user simply needs to click on the item with the left mouse button. 
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Figure 4.2: Meta Data Tree with Two Database Connection 

4. Content of The Relations 

The panel on the right side of the screen also displays the relation’s content. In 
order to view the content of any relation, the user needs to select first the panel’s data tab 
and then the relation desired. 
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Figure 4.3 : Content of the Relation, Student 

5. Regular Query Execution 

The right panel’s SQL tab is used as a text editor for SQL queries. The user can 
enter a regular query on the text area and run this query by clicking the execute query 
button. The result of the query will show up on the result table. As an example, the query 
“Select * from student where age>20” is entered on the SQL text editor, is executed, 
and the result is displayed. 
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Figure 4.4: Regular Query Execution 
6. Execution of Basic Operators 

The user needs to select the main panel’s DFQL tab to create a DFQL operator. 
There are six basic operators; these are. Select, Project, Join, Union, Difference and 
Group count. In order to create one of the six operators, the basic panel must be selected 
from the operator panel. After these selections are made, clicking on the empty canvas 
displays the basic operators list. 

a. Execution of DFQL Operator - Select 

The user selects the select operator from this list, or from the operator tab. 
After selection, the property window of this operator is displayed. The user gives this 
operator a name, enters a relation and a condition, and chooses a display mode. Then the 
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user clicks the OK button to accept the input. Finally, from the toolbar or the DFQL 
menu, the user selects the execute button to run this operator. 


For this example query, “Select * from student where age>20” is used. 
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Figure 4.5: Operator Select Property Window 
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Figure 4.6: Execution of Operator - Select 



































b. 


Execution ofDFQL Operator - Project 


The user selects the project operator from this list, or from the operator 
tab. After selection, the property window of this operator is displayed. The user gives this 
operator a name, enters a relation and an attiribute, and chooses a display mode. Then the 
user clicks the OK button to accept the input. Finally, from the toolbar or the DFQL 
menu, the user selects the execute button to run this operator. 


For this example query, “Select sname from student” is used. 


^Project HEIB 


; Name |Proiect2 I 

’Relation Istadait ’^1 

, Att. List Isname I 

✓i Jjspteyj I Cancel | OK | 


Figure 4.7: Operator Project Property Window 
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Figure 4.8: Execution of DFQL Operator - Project 
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c. Execution ofDFQL Operator - Join 

The user selects the join operator from this list, or from the operator tab. 
After selection, the property window of this operator is displayed. The user gives this 
operator a name, enters two relations, a condition, and a relation operator, and chooses a 
display mode. Then the user clicks the OK button to accept the input. Finally, from the 
toolbar or the DFQL menu, the user selects the execute button to ran this operator. 

For this example query, “Select distinct * from Course c, Enroll e where 
c.cid = e.cid” is used. 



Figure 4.9: Operator Join Poperty Window 


Figure 4.10: Execution of DFQL Operator - Join 
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d. Execution of DFQL Operator - Union 

The user selects the union operator from this list, or from the operator tab. 
After selection, the property window of this operator is displayed. The user gives this 
operator a name, enters two relations, and chooses a display mode. Then the user clicks 
the OK button to accept the input. Finally, from the toolbar or the DFQL menu, the user 
selects the execute button to run this operator. 

For this example query, “Select distinct * from (select distinct tname 
from Teacher) union select distinct * from (select distinct sname from Student)” is 

used. 
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Bbispi'ayj 



Figure 4.11: Operator Union Property Window 
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Figure 4.12: Execution of DFQL Operator - Union 
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e. Execution ofDFQL Operator - Difference 
The user selects the diff operator from this list, or from the operator tab. 
After selection, the property window of this operator is displayed. The user gives this 
operator a name, enters two relations and an attribute for comparison, and chooses a 
display mode. Then the user clicks the OK button to accept the input. Finally, from the 
toolbar or the DFQL menu, the user selects the execute button to run this operator. 

For this example query, “Select distinct cid from (select distinct cid 
from Course) S where S.cid not in(select cid from (select distinct cid from Enroll))” 

is used. 



Figure 4.13: Operator Difference Property Window 



Figure 4.14: Execution of DFQL Operator - Diff 
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f. Execution of DFQL Operator - GroupCnt 
The user selects the groupCnt operator from this list, or from the operator 
tab. After selection, the property window of this operator is displayed. The user gives this 
operator a name, enters a relation, a grouping attribute and a count attribute, and chooses 
a display mode. Then the user clicks the OK button to accept the input. Finally, from the 
toolbar or the DFQL menu, the user selects the execute button to run this operator. 

For this example query, “Select distinct gender, count (*) As 
numgender from Student group by gender” is used. 



Figure 4.15: Operator GroupCnt Property Window 



Figure 4.16: Execution of DFQL Operator - GroupCnt 
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7. Execution of Advanced Operators 

The user needs to select the main panel’s DFQL tab to create a DFQL operator. 
There are seven advanced operators; these are Eqjoin, GroupAllSatisfy, GroupNSatisfy, 
GroupMax, GroupMin, GroupAvg and Intersect. In order to create one of the seven 
operators, the advanced panel must be selected from the operator panel. After these 
selections are made, clicking on the empty canvas displays the basic operators list. 

a. Execution of DFQL Operator - Eqjoin 

The user selects the eqjoin operator from this list, or from the operator tab. 
After selection, the property window of this operator is displayed. The user gives this 
operator a name, enters two relations and an attribute, and chooses a display mode. Then 
the user clicks the OK button to accept the input. Finally, from the toolbar or the DFQL 
menu, the user selects the execute button to mn this operator. 

For this example query, “Select distinct * from Course sl^nroU s2 
where sl.cid = s2.cid” is used. 


Eqjoin HBE 


■ Narfne lEgioinil \ 

Relatronl. | Course 

I Enron ^1 

JdInAttList Icid I 

^ I Cancel | CK | , 

Figure 4.17: Operator Eqjoin Property Window 
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jdbc:odbc:studenldb1 



Figure 4.18: Execution of DFQL Operator - Eqjoin 
b. Execution of DFQL Operator - GroupAllSatisfy 

The user selects the groupAllSat operator from this list, or from the 
operator tab. After selection, the property window of this operator is displayed. The user 
gives this operator a name, enters a relation, a grouping attribute and a condition, and 
chooses a display mode. Then the user clicks the OK button to accept the input. Finally, 
from the toolbar or the DFQL menu, the user selects the execute button to run this 
operator. 


For this example query, “Select distinct cid, sid from Enroll where 


grade>’a' group by cid, sid” is used. 
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Figure 4.19: Operator GroupAllSatisfy Property Window 



Figure 4.20: Execution of DFQL Operator - GroupAllSat 
c. Execution of DFQL Operator - GroupNSatisJy 

The user selects the groupNSat operator from this list, or from the operator 
tab. After selection, the property window of this operator is displayed. The user gives this 
operator a name, enters a relation, a grouping attribute and a condition, and chooses a 
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display mode. Then the user clicks the OK button to accept the input. Finally, from the 
toolbar or the DFQL menu, the user selects the execute button to run this operator. 


For this example query, “Select distinct sid, cid from Enroll where 
grade=’a’ group by sid, cid having count (*) <2” is used. 



Figure 4.21: Operator GroupNSatisfy Property Window 



Figure 4.22 : Execution of DFQL Operator - GroupNSat 
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d. 


Execution ofDFQL Operator - GroupMax 


The user selects the groupMax operator from this list, or from the operator 
tab. After selection, the property window of this operator is displayed. The user gives this 
operator a name, enters a relation, a grouping attnibute and an aggragate attribute, and 
chooses a display mode. Then the user clicks the OK button to accept the input. Finally, 
from the toolbar or the DFQL menu, the user selects the execute button to run this 
operator. 

For this example query, “Select distinct gender, max (age) as max_age 
from Student group by gender” is used. 



Figure 4.23; Operator GroupMax Property Window 



Figure 4.24: Execution ofDFQL Operator - GroupMax 
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e. Execution of DFQL Operator - GroupMin 
The user selects the groupMin operator from this list, or from the operator 
tab. After selection, the property window of this operator is displayed. The user gives this 
operator a name, enters a relation, a grouping attrribute and an aggragate attribute, and 
chooses a display mode. Then the user clicks the OK button to accept the input. Finally, 
from the toolbar or the DFQL menu, the user selects the execute button to run this 
operator. 

For this example query, “Select distinct gender, min (age) as niin_age 
from Student group by gender” is used. 



Figure 4.25: Operator GroupMin Property Window 



Figure 4.26: Execution of DFQL Operator - GroupMin 
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/. Execution ofDFQL Operator - GroupAvg 

The user selects the groupAvg operator from this list, or from the operator 


tab. After selection, the property window of this operator is displayed. The user gives this 
operator a name, enters a relation, a grouping attrribute and an aggragate attribute, and 
chooses a display mode. Then the user clicks the OK button to accept the input. Finally, 
from the toolbar or the DFQL menu, the user selects the execute button to run this 
operator. 

For this example query, “Select distinct gender, avg (age) as avg_age 
from Student group by gender” is used. 



Figure 4.27: Operator GroupAvg Property Window 



Figure 4.28: Execution ofDFQL Operator - GroupAvgn 
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g. Execution ofDFQL Operator — Intersect 

The user selects the intersect operator from this list, or from the operator 
tab. After selection, the property window of this operator is displayed. The user gives this 
operator a name, enters a relation and an attribute and chooses a display mode. Then the 
user clicks the OK button to accept the input. Finally, from the toolbar or the DFQL 
menu, the user selects the execute button to ran this operator. 

For this example query, “Select distinct sname from (select distinct * 
from Student where age >25) S where S.sname in(select sname from (select distinct 
* from Student where age<20))” is used. 



Figure 4.29: Operator Intersect Property Window 



Figure 4.30: Execution of DFQL Operator - Intersect 

48 















8. Execution of Incremental Query 

The user can construct incremental queries by connecting the operators. Each 
operator’s output is a relation by itself. The query “select distinct sname from (select 
distinct * from (select distinct * from Enroll where grade = 'a') j4,Student j41 where 
j4.sid = j41.sid)” will be used to show how to create an incremental query in DFQL 
using the operators. This query retrieves the name of the students who gets a grade of ‘A’ 
in at least one of his courses. 

First, the query chooses all the records from the “enroll” table with condition 
“grade = ‘a’”. The query joins this result with another relation, “student”, with the 
condition that both “sid”’s are the same. Finally, program displays the name of the 
students from the result of the join. 



Figure 4.31: Execution of an Incremental DFQL Query 
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9. Execution of User Defined Operator 

The user needs to select the main panel’s DFQL tab to create a DFQL operator. In 
order to create a user defined operator, the user defined panel must be selected from the 
operator panel. After these selections, clicking on the empty canvas or pressing the new 
button displays the user defined operator construction screen. 


User Defined Operator 
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Cancel 


Figure 4.32; User Defined Operator Construction Screen 

This screen allows user to specify the new operator. The user needs to enter a 
name and number of the relations, conditions and attributes for this new operator. After 
entering this information, the user presses the proceed button. For this example, a selproj 
operator is created, which is the combination of the select and project operators. 

Now, the user needs to select which operators are going to be combined to 
produce the new operator. The user selects the operators from the combo box by 
choosing the operator and pressing the add button. First, the user selects the operator 
select. 
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Figure 4.35: Load User Defined Operator 


The new operator’s property window is displayed, when the loading process ends. 
The user enters the required information for the new operator. For this example, we used 
the query, “select distinct sname from (select distinct * from Student where age>23),” 
which retrieves the names of the students who are older than 23. 



Figure 4.36: SelProj Operator Property Window. 

This operator can be placed and run in the same way as the other operators. The 
user selects the execute button to run this operator. 
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Figure 4.37; Run Operator Selproj 
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V. CONCLUSIONS AND RECOMMENDATIONS 


Previous work mentioned in background chapter (Chapter I) establishes that 
DFQL is capable of solving problems encountered when using SQL and QBE, such as 
inability to express universal quantification and specify complex nested queries. This 
thesis research attempts to demonstrate that DFQL can be implemented as powerfully, 
simply, and intuitivly as its creators stipulate. All of the functionalities of this application 
have been tested and are working properly based on the design requirements. 

This application provides the user with a very simple and powerful graphical user 
interface. By providing database connection information, the user can log onto one or 
more databases concurrently. 

The application allows user to view the database metadata and the contents of the 
relations in the database. 

Users can query the databases by using either the SQL text editor or the DFQL 
visual query constractor. 

hi order to create DFQL queries, the user can use built-in operators, or can create 
user-defined operators. 

Query results can be printed. Queries and user-defined operators can be saved and 
opened for future use. 

Because this is an early version of this application, there are design modifications 
which should be considered in order to enhance the application’s effectiveness. 
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In our design, JPanel class is used to display the DFQL operators. Since the area 
for the panel cannot be extended, it gives the user a limited area to create operators. 
Extending the Scrollable class is a possible solution for this problem; however this option 
requires additional coding. 

To improve the user friendliness, this application can be designed in a way that, 
users are able to drag and drop an operator onto the DFQL query design area. On this 
design area users can click on the input nodes in order to enter the corresponding input 
values. 

This application works with multiple databases running concurrently. Application 
sends the same query to all databases connected. The problem with is that the databases 
connected must be identical. They must have the same structure. This feature, working 
with multiple databases, is designed to allow the user to work with distributed databases. 

Although this application was tested several times and the encountered bugs were 
corrected. Hence it is recommended that a beta version of this application be released. 
And new patches should be released, according to the user compliances. 
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APPENDIX-A 


SOURCE CODE 


1. Adyancedoperatorsjaya 

package ThesisGUI; 

import java.awt. *; 
import javax.swing. *; 
import java.awt.event.*; 

/** 

* This frame is used to display the advanced DFQL operators and allows user to 

* select one of them. 

* 

* AUTHOR : IS & BA 

public class AdvancedOperators extends JFrame implements WindowListener { 
/** Operator EQJoin**/ 

JButton btnEqjoin = new JButton(); 

/** Operator Group All Satisfy**/ 

JButton btnGipAllSat = new JButton(); 

/** Operator Group Number Satisfy**/ 

JButton btnGrpNSat = new JButton(); 

/** Aggregate Operators 

* Maximum**/ 

JButton btnGrpMax = new JButton(); 

/** Aggregate Operators 

* Average**/ 

JButton btnGrpAvg = new JButtonQ; 

/** Aggregate Operators 

* Minimum**/ 

JButton btnGrpMin = new JButtonQ; 

/** Operator Intersect**/ 

JButton btnintersect = new IButtonQ; 
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/** Cancel button **/ 

JButton btnCancel = new JButton(); 

/** X coordinate of the new operator**/ 
int x; 


/** Y coordinate of the new operator**/ 
inty; 

/* CONSTRUCTOR */ 

* The constructor 

* @param x and y coordinates of the new operator 
**! 

public AdvancedOperators(int x, int y) { 
try { 

this.x = x; 
this.y = y; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 


/* INTTIATE METHOD */ 

!** 

* The initiation 

* creates the frame, and the buttons. Initiates them. 

private void jblnit() throws Exception { 
this.getContentPane().setLayout(null); 
this.setTitle ("Advanced"); 

btnEqjoin.setText ("Eqjoin"); 

btnGrpAllSat.setText ("GrpAllSat"); 


btnGrpNSat.setText 

btnGrpMax.setText 

btnGrpAvg.setText 

btnGrpMin.setText 

btalntersectsetText 

btnCancel.setText 


("GrpNSat"); 

("GrpMax"); 

("GrpAvg"); 

("GipMin"); 

("Intersect"); 

("Cancel"); 


btnEqjoin.setBounds (new Rectangle(l, 3,111,16)); 
btnEqjoin.addActionListener (new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnEqjoin_actionPerformed(e); } }); 
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btnGrpAllSat.setBounds (new Rectangle( 1,19,111,16)); 

btnGrpAllSat.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerfonned(ActionEvent e) { 
btnGrpAllSat_actionPerfonned(e); 

}}); 

btnGrpNSat-setBounds (new Rectangle( 1,35, 111, 16)); 

btnGipNSat.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerfonned(ActionEvent e) { 
btnGipNSat_actionPeiformed(e); 

}}); 

btnGrpMax.setBounds (newRectangle(l, 51, 111, 16)); 
btnGrpMax.addActionListener (new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnGrpMax_actionPeiformed(e); 

}}); 

btnGrpAvg.setBounds (new Rectangle(l, 67, 111, 16)); 
btnGrpAvg.addActionListener (new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnGrpAvg_actionPerformed(e); 

}}); 

btnGrpMin.setBounds (newRectangle(l, 83, 111, 16)); 
btnGrpMin.addActionListener (new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnGrpMin_actionPerformed(e); 

}}); 

btnIntersect.setBounds (new Rectangle( 1,99,111,16)); 

btnIntersect.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnIntersect_actionPerformed(e); 

}}); 

btnCancel.setBounds (newRectangle(l, 115, 111, 16)); 
btnCancel.addActionListener (new java.awt.event.ActionListener() { 
public void actionPerfomied(ActionEvent e) { 
btnCancel_actionPerforaied(e); 

}}); 

btnCancel. setForeground(Color.red); 
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this .getContentPane().add(btnEqj oin, null); 
this.getContentPane0.add(btnGrpNSat,null); 
this.getContentPane().add(btnGipMax, null); 
this.getContentPane().add(btnGrpAvg, null); 
this.getContentPane().add(btnGipMin, null); 
this.getContentPane0.add^tnGrpAllSat,null); 
this.getContentPane().add(btnIntersect, null); 
this.getContentPane().add(btnCancel, null); 

this.setBounds(x,y, 120,160); 
this.show(true); 

} 



WINDOW ACTIVATIONS 


*/ 


* The window listener methods 

* @param event (WindowEvent) 

public void windowClosing 
public void window Activated 
public void windowClosed 
public void windowDeactivated 
public void windowDeiconified 
public void windowiconified 
public void windowOpened 


(WindowEvent event) {this.dispose(); } 
(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 


/* ACTION PERFORMED METHODS */ 

* The Eqjoin button action performed 

* When user selects this button, program creates an 

* EQJoin operator with the given coordinates 
,* @see OperatorEqjoin 

void btnEqjoin_actionPerformed(ActionEvent e) { 
OperatorEqjoin eqjoin = new OperatorEqjoin(x,y); 
this.disposeO; } 


* The Group all satisfy button action performed 

* When user selects this button, program creates a 

* group all satisfy operator with the given coordinates 

* @see OperatoiGrpAllSat 
**/ 

void btnGrpAllSat_actionPerformed(ActionEvent e) { 
OperatorGrpAllSat grpAllSat = new OperatorGrpAllSat(x,y); 
this.disposeO; } 
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!** 

* The Group number satisfy button action performed 

* When user selects this button, program creates a 

* group number satisfy operator with the given coordinates 

* @see OperatorGrpNSat 
**/ 

void btnGrpNSat_actionPerformed(ActionEvent e) { 
OperatorGrpNSat grpNSat = new OperatorGrpNSat(x,y); 
this.disposeQ; 

} 


* The Group maximum button action performed 

* When user selects this button, program creates a 

* group maximum operator with the given coordinates 

* @see OperatorGrpMax 
**! 

void btnGrpMax_actionPerformed(ActionEvent e) { 
OperatorGrpMax grpMax = new OperatorGrpMax(x,y); 
this.disposeQ; 

} 


* The Group minimum button action performed 

* When user selects this button, program creates a 

* group minimum operator with the given coordinates 

* @see OperatorGipMin 

**j 

void btnGrpMin_actionPerformed(ActionEvent e) { 
OperatorGrpMin grpMin = new OperatorGipMin(x,y); 
this.disposeQ; 

} 


!** 

* The Group average button action performed 

* When user selects this button, program creates a 

* group average operator with the given coordinates 

* @see OperatorGrpAvg 

**/ 

void btnGrpAvg_actionPerformed(ActionEvent e) { 
OperatorGrpAvg grpAvg = new OperatorGrpAvg(x,y); 
this.disposeQ; 

} 
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* The Intersect button action performed 

* When user selects this button, program creates an 

* intersect operator with the given coordinates 

* @see Operatorintersect 
**! 

void btnIntersect_actionPerformed(ActionEvent e) { 
Operatorintersect intersect = new OperatorIntersect(x,y); 
this.disposeQ; 

} 

* The Cancel button action performed 

* Terminates this frame without creating an operator 

void btnCancel_actionPerformed(ActionEvent e) { 
this.disposeQ; 

} 

} 

Attribute.Java 


package ThesisGUI; 
import java.util.*; 


* This class holds the data for an attribute. 

* ©author IS & BA 

**j 

Public class Attribute { 

/** Name of the attribute **/ 
private String name; 

/** Type of the attribute **/ 
private String dataType; 

/** Field size of the attribute **/ 
private int fieldSize; 

/** Nullability of the attribute. 0- Not Nullable, 1- Nullable, 2- Unknown**/ 
private int nullable; 

/** Check whether the values of this attribute can be used in WHERE clause 
True- Searchable, False - otherwise**/ 
private boolean searchable; 
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/** Case-sensitivity of the attribute values. True- caseSensitive, False - 
otherwise**/ 

private boolean caseSensitive; 

/* CONSTRUCTOR */ 

* The constructor 
**! 

public Attribute () { 


name 

= null; 

dataType 

= null; 

fieldSize 

= -l; 

nullable 

= 2; 

searchable 

= true; 

caseSensitive 

= false; 


} 


/* Get Methods */ 

/** 

* Gets the name of the attribute 

**/ 

public String getAttributeName () { 
return name; 

} 


/** 

* Gets the type of the attribute 

public String getAttributeType () { 
return dataType; 

} 

/** 

* Gets the size of the attribute 

**l 

public int getAttributeSize () { 
return fieldSize; 

} 


/** 

* Returns the nullability of the attribute 

* @see nullable 
**/ 

public int isNullable() { 
return nullable; } 
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/** 

* Returns the searchability of the attribute 

* @see searchable 
**/ 

public boolean isSearchable() { 
return searchable; 

} 


* Returns the case-sensitivity of the attribute 

* @see caseSensitive 

public boolean isCaseSensitive() { 
return caseSensitive; 

} 


/* Set Methods */ 

* Sets the name of the attribute 

* ©parameter attName (String) 

protected void setAttributeName (String attName) { 
name = attName; 

} 

/** 

* Sets the type of the attribute 

* ©parameter attType (String) 

**/ 

protected void setAttributeType (String attType) { 
dataT)^e = attType; 

} 


* Sets the size of the attribute 

* ©parameter attSize (String) 

protected void setAttributeSize (int attSize) { 
fieldSize = attSize; 

} 


/** 

* Sets the nullability of the attribute 

* ©parameter nullindex (int) 
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protected void setNullable (int nulllndex){ 
nullable = nullindex; 

} 


* Sets the searcability of the attribute 

* ©parameter search (boolean) 

protected void setSearchable (boolean search) { 
searchable = search; 

} 

!** 

* Sets the case-sensitivity of the attribute 

* ©parameter caseSense (boolean) 

**/ 

protected void setCaseSensitive (boolean caseSense) { 
caseSensitive = caseSense; 

} 

} 


3. BasicOperators.Jaya 

package ThesisGUI; 

import j ava.awt. *; 
import javax.swing.*; 
import j ava.awt.event. *; 

/** 

* This frame is used to display the basic DFQL operators and allows user to 

* select one of them. 

* 

* AUTHOR ; IS & BA 

**/ 

public class BasicOperators extends JFrame implements WindowListener { 
/** Operator Project**/ 

JButton btnProject = new JButton(); 

/** Operator Select**/ 

JButton btnSelect = new JButton(); 

/** Operator Join**/ 

JButton btnJoin = new JButton(); 
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/** Operator Union**/ 

JButton btnUnion = new JButtonQ; 

/** Operator Different**/ 

JButton btnDiff = new JButton(); 

/** Operator Group count**/ 

JButton btnGroupCnt = new JButtonQ; 

/** cancel button **/ 

JButton btnCancel = new JButtonQ; 

/** X coordinate of the new operator**/ 
int x; 

/** Y coordinate of the new operator**/ 
inty; 

/* CONSTRUCTOR */ 

* The constructor 

* @param x and y coordinates of the new operator 
**! 

public BasicOperators(int x, int y) { 
try { 
this.x=x; 
this.y=y; 
jblnitQ; 

} 

catch(Exception e) { 
e.printStackTraceQ; 

} 

} 

/* INITIATE METHOD */ 

* The initiation 

* creates the frame, and the buttons. Liitiates them. 
**/ 

private void jblnitQ throws Exception { 
this.getContentPaneQ.setLayout(null); 
this.setTitle ("Basic"); 

btnSelect.setText ("Select"); 
btnProject.setText ("Project"); 
btnJoin.setText ("Join"); 
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btnUnion.setText ("Union"); 
btnDiff.setText ("Diff"); 
btnGroupCnt.setText ("GroupCnt"); 
btnCancel.setText ("Cancel"); 

btnSelect.setBounds (newRectangle(l, 3, 111, 16)); 

btnSelect.addActionListener (new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnSelect_actionPerformed(e); 

}}); 

btnProject.setBounds (newRectangle(l, 19, 111, 16)); 

btnProject. addActionListener(new j ava. awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnProject_actionPerfomied(e); 

}}); 

btnJoin.setBounds (new Rectangle(l, 35, 111, 16)); 
btnJoin.addActionListener (new java.awt.event.ActionListener() { 
public void actionPerfomied(ActionEvent e) { 
btnJoin_actionPerformed(e); 

}}); 

btnUnion.setBounds (newRectangle(l, 50, 111, 16)); 
btnUnion.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnUnion_actionPerformed(e); 

}}); 

btnDiff.setBounds (new Rectangle( 1,66, 111, 16)); 
btnDiff.addActionListener (new java.awt.event.ActionListener() { 
public void actionPerfornied(ActionEvent e) { 
btnDiff_actionPerformed(e); 

}}); 

btnGroupCnt.setBounds (newRectangle(l, 82, 111, 16)); 
btnGroupCnt.addActionListener (new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnGroupCnt_actionPerformed(e); 

}}); 

btnCancel.setBounds (newRectangle(l, 102, 111, 16)); 
btnCancel.addActionListener (new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnCancel_actionPerformed(e); 

}}); 
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btnCancel.setForeground(Color.red); 

this.getContentPane().add(btnSelect, null); 
this.getContentPane().add(btnJoin, null); 
this.getContentPaneQ.addCbtnUnion, null); 
this.getContentPane().add(btnDiff, null); 
this.getContentPane0.add(btnGroupCnt, null); 
this.getContentPane0.add(btnProject, null); 
this.getContentPane().add(btnCancel, null); 
this.setBounds(x,y,120,150); 
this.show(true); 

} 


/* WINDOW ACTIVATIONS 


!** 

* The window listener methods 

* @param event (WindowEvent) 
**/ 

public void windowClosing 
public void window Activated 
public void windowClosed 
public void windowDeactivated 
public void windowDeiconified 
public void windowiconified 
public void windowOpened 


*/ 


(WindowEvent event) {this.dispose();} 
(WindowEvent event) {} 
(WindowEvent event) {} 
(WindowEvent event) {} 
(WindowEvent event) {} 
(WindowEvent event) {} 
(WindowEvent event) {} 


/* ACTION PERFORMED METHODS 

/** 

* The Select button action performed 

* When user selects this button, program creates an 

* Select operator with the given coordinates 

* @see OperatorSelect 

void bmSelect_actionPerformed(ActionEvent e) { 
OperatorSelect select = new OperatorSelect(x,y); 
this.disposeO; 

} 


* The Project button action performed 

* When user selects this button, program creates an 

* Project operator with the given coordinates 

* @see OperatorProject 
**! 

void btnProject_actionPerformed(ActionEvent e) { 


*/ 
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OperatorProject project = new OperatorProject(x,y); 
this.disposeO; 

} 

!** 

* The Join button action performed 

* When user selects this button, program creates an 

* Join operator with the given coordinates 

* @see OperatorJoin 

void btnJoin_actionPerformed(ActionEvent e) { 
OperatorJoin join = new OperatorJoin(x,y); 
this.disposeO; 

} 


* The Union button action performed 

* When user selects this button, program creates an 

* Union operator with the given coordinates 

* @see OperatorUnion 

void btnUnion_actionPerformed(ActionEvent e) { 
OperatorUnion union = new OperatorUnion(x,y); 
this.disposeO; 

} 


!** 

* The Diferent button action performed 

* When user selects this button, program creates an 

* Different operator with the given coordinates 

* @see OperatorDiff 
**! 

void btnDiff_actionPerformed(ActionEvent e) { 
OperatorDiff diff = new OperatorDiff(x,y); 
this.disposeO; 

} 


* The Group count button action performed 

* When user selects this button, program creates an 

* Group count operator with the given coordinates 

* @see OperatorGrpCnt 
**! 

void btnGroupCnt_actionPerformed(ActionEvent e) { 
OperatorGroupCnt groupCnt = new OperatorGroupCnt(x,y); 
this.disposeO; } 
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* The Cancel button action performed 

* Terminates this frame without creating an operator 
**/ 

void bmCancel_actionPeiformed(ActionEvent e) { 
this.disposeO; 

} 

} 


4. Databasejava 


package ThesisGUI; 


import java.sql.*; 
import javax.swing.*; 
import javax.swing.tree.*; 
import java.util.*; 
import java.util.Date; 

* This class manages the connection with JDBC database. A database object 

* encapsulates the functionalities provided the Connection, Statement, and 

* other JDBC classes 

* ©author BA & IS 

public class Database { 

* This object represents the connection session with a database and 

* includes the SQL statements and their results. 

private Connection connection; 

/** 

* This object is used to send SQL statements to the connected database 
**/ 

private Statement statement; 


* The result set of the last query execution 
private ResultSet queiyResult; 
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* The meta data of the result set from the last query execution 
private ResultSetMetaData queryResultMetaData; 

!** 

* The current relation being executed 
private Table currentQuery; 

/** 

* The connection info of the database 

* @see Databaseinfo 
**! 

private Databaseinfo databaseinfo; 




* The meta data of the database 

**! 

private DatabaseMetaData metaData; 


!** 

* If the database supports ANSI92 Full SQL. True-Supports, False-otherwise 

**! 

private boolean support; 

* The keywords supported by this database 
private String keywords; 

* The number of the tables in the database 
**! 

private int tableCount; 


* Queries executed in the current session 

**j 

private Vector queries; 

!** 

* Boolean to synchronize the program with the database 

**! 

private boolean askDB; 
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* Boolean to decide if the executed query information is going to be stored, 
private boolean store; 


* The time period for program to synchronize with the database (in minutes) 


private int updatePeriod; 


* DefaultMutableTreeNode which contains the tree structure of the database 
**/ 

private DefaultMutableTreeNode dbTreeNode; 

/* CONSTRUCTOR *! 

/** 

* The constructor 

* @param databaselnfo the information to connect a database 

* @ see Databaselnfo 
**/ 

public Database(DatabaseInfo databaselnfo) ( 
this.databaselnfo = databaselnfo; 

} 

/* PUBLIC METHODS */ 


* Connects to a JDBC-compliant database 
**/ 

public void connect () throws ClassNotFoundException, SQLException { 
Class.forName(databaseInfo.driver()); 

, connection = DriverManager.getConnection (databaseInfo.url(), 

databaseInfo.useridO, 

databaselnfo.passwordO); 

statement = connection.createStatement(); 

metaData = connection.getMetaData(); 

support = metaData.supportsANSI92FullSQL(); 

keywords = metaData.getSQLKeywords(); 

tableCount = 0; 

queries = new Vector(); 

askDB = false; 

updatePeriod =15; 

store = true; 
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// finds and stores the database table information 

initiateTablesO; 

store = false; 

constractTreeNodeQ; 

} 

* Disconnects from the connected database 
**/ 

public void disconnect () { 
try { 

statement.closeO; 

connection.closeO; 

} 

catch (SQLException e) { 
System.out.println(e.getMessage()); 

} . 


* Executes the query 

* If the same query is executed before, this method returns the relation 

* from the query history vector (queries). 

* @param query is the query to be executed in SQL S)mtax 

* ©return the table object after the execution of the query 

**j 

public Table executeQuery (String query) throws SQLException { 
query = connection.nativeSQL(query); 

// translate query into the native query language of the connected DBMS 

query = query.toLowerCase(); // convert to lower case. 

Table temp = checkQuery(query); // check if the query is executed before 

// if the query is not executed before or it is out of date 
if (temp == null) { 

queryResult = statement.executeQuery(query); 
if (queryResult != null) { 

queryResultMetaData = queryResult.getMetaData(); 
currentQuery = new Table(queiy,this); 
currentQuery.setTableName("query"+queries.size()); 
if (store) { 

queries .add(currentQuery); 

} 

} 
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// if the executed query does not produce a result set. 
else { 

currentQuery = null; 

} 

} 

// if the query is executed before 
else { 

compareTimeStamp(temp); 

// If the relation needs to be updated 
if(askDB) { 

// Execute the query 

queryResult = statement.executeQuery(tenip.getQuery()); 
queryResultMetaData = queryResult.getMetaData(); 

// Update the relation data 
temp.updateRelationDataO; 
askDB = false; 

} 

currentQuery = temp; 

} 

return currentQuery; 

} 

!** 

* ©return a vector which contains the table names in the Database 
(String vector) 

**! 

public Vector getTableNames() { 

Vector tableNames = new Vector(); 

for (int namelndex=0; nameindex < tableCount; nameIndex-H-) { 
Table temp = (Table)queries.elementAt(namelndex); 
tableNames.add(temp.getTableName()); 

} 

return tableNames; 


!** 

* ©return boolean 

* ©see support 
**! 

public boolean isSupportANSI92(){ 
return support; 

} 
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public String getS QLKeywords() { 
return keywords; 

} 

* ©return the product name of the database program 
**! 

public String getDatabaseProgramName () throws SQLException { 
return (metaData.getDatabaseProductName()); 

) 

!** 

* @param tableName the relation name as String 

* ©return a vector which contains the attributes of the relation 

* (Attribute Vector) 

* ©see Attribute class 

public Vector getTableAttributes (String tableName) throws SQLException{ 
int tableindex = findTable(tableName); 
if (tableindex ==-!){ 
return null; 

} 

else { 

Table currentTable = (Table)queries.elementAt(tablelndex); 
return currentTable.getAttributes(); 

} 


!** 

* ©param tableName the relation name as String 

* ©return a vector which contains the attribute names of the relation 

* (String Vector) 

**! 

public Vector getTableAttributeNames (String tableName) throws 

SQLException{ 

int tableindex = findTable(tableName); 
if (tableindex ==-!){ 
return null; 

} 

else { 

Table currentTable = (Table)queries.elementAt(tablelndex); 
return currentT able.getAttributeNames(); 

} 

} 
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* ©return DefaultMutableTreeNode - contains the tree model of the database 

public DefaultMutableTreeNode getTreeModel () { 
return dbTreeNode;} 


* ©pararn tableName the relation name whose data is being asked 

* ©return a vector which contains the table data, provided table name 

public Vector getTableData(String tableName) throws SQLException{ 
int tableindex = findTable(tableName); 
if (tableindex — -1) { 
return null; 

} 

else { 

Table temp = (Table)queries.elementAt(tablelndex); 
executeQuery(temp.getQuery()); 
return temp.getData(); 

} 


* ©return all the queries executed in the current session 
**/ 

public Vector getQueryHistoryO { 
return queries; 

} 


/** 

* ©return Update time interval 

* ©see updatePeriod 

public int getUpdateTime(){ 
return updatePeriod; 

} 

public boolean isStore(){ 
return store; 

} 

public boolean isAskDB(){ 
return askDB; 

} 
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/** 

* Sets the 'askDB' data member. 

* This data member is used to tell the program that the relation data needs 

* to be updated. This data member can be set either by the user or 

* by the program itself. 

* @param update the new value of the variable askDB 

* @see askDB 

public void setAskDB (boolean update) { 
askDB = update; 

} 


* Sets the 'updatePeriod' data member. 

* @param newPeriod the new value of the variable updatePeriod as Integer 

* @see updatePeriod 


public void setUpdatePeriod (int newPeriod) { 
updatePeriod = newPeriod; 

} 

public void setStore (boolean newStore) { 
store = newStore; 

} 

public String getURL() { 
return databaseInfo.url(); 

} 

public String getUserName() { 
return databaseInfo.userid(); 

} 

public String getDriver() { 
return databaseInfo.driver(); 

} 


/* PRIVATE METHODS */ 

/** 

* Initiates the relations of the database (including data) 

private void initiateTables(){ 
try { 

String tableName; 

String [] type = {"TABLE"}; 
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ResultSet rs = metaData.getTables(null,null,null,type); 
while (rs.nextO) { 

tableName = rs.getString(rs.getMetaData().getColumnName(3)); 
Table currentTable = this.executeQueryC'select * from " + tableName); 

currentT able. setT ableN ame(tableName); 
tableCount-H-; 

} 

} 

catch (SQLException e){ 

System.out.println(e.getMessage()); 

) 

} 


* @param tableName the relation name (in String) 

* ©return the index of the table in the Table vector 
**! 

private int findTable(String tableName) { 
int result = -1; 

tableName = tableName.toLowerCase(); 

for (int tableindex = 0 ; tableindex < queries.size(); tablehidex-H-) { 
Table temp = (Table) queries.elementAt(tablelndex); 
if (tableName.equals(temp.getTableName().toLowerCase())) { 
result = tablehidex; 
break; 

} 

} 

return result; 

} 


* Compares the current date with the query's time stamp. If the difference is 

* greater than the updatePeriod, it sets the askDB parameter to TRUE. 

* @param checkRelation the table object whose time stamp going to be 

* checked. 

* @see askDB 

* ©see updatePeriod 
**/ 

private void compareTimeStamp (Table checkRelation) { 

Date executionDate = checkRelation.getTimeStampO; 

Date currentDate = new Date(); 

int executionMinute = (executionDate.getDay()*24 + 
executionDate.getHours())*60+executionDate.getMinutes(); 
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int currentMinute = (currentDate.getDay()*24 + 
currentDate.getHours())*60 + 
currentDate.getMinutesQ; 

if (currentMinute-executionMinute >= updatePeriod) { 
askDB = trae; 

} 

} 


* Checks if the query is executed before. If so, returns the Table object 

* @param queryCheck the query which will be checked (String) 

* ©return a Table object 
**/ 

private Table checkQuery(String queryCheck) { 

Table temp = null; 

for (int index = 0; index < queries.size(); index-H-) { 
temp = (Table) queries.elementAt(index); 
if (temp.getQuery().equals(queryCheck)) { 
break; 

} 

else { 

temp = null; 

} 

} 

return temp; 

} 


* Generates the tree model of the database and stores the information 

* in the dbTreeNode data member 

* ©see dbTreeNode 

**/ 

private void constmctTreeNode(){ 

DefaultMutableTreeNode top = new DefaultMutableTreeNode 
(databaseInfo.urlO); 

DefaultMutableTreeNode parent = top; 

DefaultMutableTreeNode node; 

Table tempT; 

Attribute tempA; 

Vector treeAttr; 

// Add the relation names to the tree model 
for (int iter=0; iter < tableCount; iter-H-) { 
tempT = (Table)queries.elementAt(iter); 
node = new DefaultMutableTreeNode(tempT.getTableName()); 
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treeAttr = tempT.getAttributes(); 


// Add the attribute names to the appropriate relation 
for (int attiter = 0; attiter < treeAttr.sizeQ; attIter-H-) { 
tempA = (Attribute)treeAttr.elementAt(attlter); 
node.add(newDefaultMutableTreeNode(tempA.getAttributeName())); 

} 

parent, add(node); 

} 

dbTreeNode = top; 

} 

/* PROTECTED METHODS */ 

/** 

* ©return the meta data of the last query execution 

protected ResultSetMetaData getQueryMetaData(){ 
return queryResultMetaData; 

} 

* ©return the Result Set of the last query execution 

protected ResultSet getQueiyResultSetO { 
return queryResult; 

} 

} 

5. Databaselnfojava 

package ThesisGUI; 

/** 

* This class keeps the four pieces of data necessary for makin g a JDBC 

* connection 

* 

* AUTHOR; BA&IS . 

**! 

public class Databaselnfo { 

/** driver of the database **/ 
private String driver; 

/** url of the database **/ 
private String url; 
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/** user name of the current user **/ 
private String userid; 


/** password for the connection **/ 
private String password; 

I* CONSTRUCTOR */ 

!** 

* Default constructor 
public DatabaseInfoO { 


this.driver 
this.url 
this .userid 
this.password 

} 


= "sun.jdbc.odbc.JdbcOdbcDriver"; 
= "jdbc:odbc:studentdb"; 

= "Anonymous"; 

= "guest"; 


* Constructor with parameters 

* ©parameters driver, url, user, pwd (String) 

public Databaseinfo (String driver. String url. String user. String pwd) { 
this.driver = driver; 
this.url = url; 
this.userid = user; 
this.password = pwd; 

} 


/* Get Methods */ 

* Gets the driver of the database 

**f 

public String driver() { 
return driver; 

} 


/** 

* Gets the url of the database 
**/ 

public String url() { 
return url; 

} 
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* Gets the user id of the current user 

public String userid() { 
return userid; } 

!** 

* Gets the password for the connection 

public String password() { 
return password; 

} 

/* Set Methods */ 

I** 

* Sets the driver of the database 

**! 

public void setDriver(String driver) { 
this.driver = driver; 

} 


* Sets the url of the database 

public void setURL(String url) { 
this.url = url; 

} 


/** 

* Sets the user id of the current user 
**/ 

public void setUserid(String user) { 
this.userid = user; 

} 


* Sets the password 

public void setPassword(String pwd) { 
this.password = pwd; 

} 

} 
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6 . 


Draw.Java 


package ThesisGUI; 

import java.awt.*; 

import java.awt.event.*; 

import javax.swing.*; 

import j avax. s wing.border. *; 

import java.awt.Toolkit; 

import javax.swing.event.*; 

import java.util.*; 

import com.borland.dbswing.*; 

import java.io.*; 

import j ava.awt.Graphics2D; 

import com.borland.jbcl.control.*; 

* It draws the operators on the canvas. Has a mouse motion listener 

* according to the mouse actions, draws an operator, deletes it, drags 

* it or displays a frame to change the operator properties. 

* after every action, all canvas repainted. 

* 

* AUTHOR: IS & BA 

**f 

public class Draw extends JPanel implements MouseMotionListener 

{ 

/** size of the operators **/ 

private static int OPERATORLENGTH = 70; 

/** max number of operators **/ 

private static final int MAXNUMOFOPERATORS = 20; 

/**current number of the operators that has been drawn.**/ 
protected int numOfOperators = 0; 

/** an array holds the drawing information**/ 

protected Operator[] operators = new Operator [MAXNUMOFOPERATORS]; 

/**if the choosen Operator is occupied (>=0) or empty (-1)**/ 
private int current = -l; 

/* CONSTRUCTOR */ 

/** 

* The constructor 
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public DrawQ 

{ 

addMouseListener (new MouseAdapter() 

{ 

public void mouseClicked(MouseEvent evt) 

{ 

Draw.this.mouseClicked(evt); 

} 

}); 

addMouseMotionListener(this); 

} 

* Automatically called by repaint method, 

* In a for loop, it calls the draw method with the index number of the operator 

* in order to draw all the operators. 

public void paint(Graphics g) 

{ 

for(int i = 0; i<numOfOperators; i++){ 
draw(g,i); 

} 

test.window.panelMain.repaint(); 

} 


* Returns the index value of the rectangle occupies this spot 

* if the spot is empty returns -1 

■■*/ 

public int find (int x, int y) 

{ 

for (int i = 0; i<numOfOperators;i++){ 

if(operators[i].x <= x && x <= operators[i].x+ OPERATORLENGTH 
&& operators[i].y <= y && y <= operators[i].y + OPERATORLENGTH/3 ) 
{ return i;} 

} 

return-1; 

} 


* draws the operator; 

* draws a rectangle, adds input and ouQ)ut nodes, draws the lines from the 

* input nodes, writes the name of the operator and input information 
**/ 
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public void draw (Graphics g, int i) 

{ 

!** Length of the name of the operator in order to center it**/ 
int lengthOfName = 6 * operators[i].name.length(); 

/** Empty space number, which will leave before and after the name**/ 
int emptySpace; 

/** The distance between the input nodes, in order to place them 
simetrically**/ 
int distanceBtwnNodes; 

/** A boolean value is used to determine whether the operator is connected to 
* another operator or connected to a string**/ 
boolean relatedToOtherOperator; 

/** List of the relations of an operator has with the other operators**/ 

Vector relationHolder = new Vector(); 

/** In order to hold the index of the operator and index of the input node**/ 
int [] include = {-1,-1}; 

if (lengthOfName<OPERATORLENGTH) { 
emptySpace = (int)(OPERATORLENGTH - lengthOfName)/2; 

} 

else( 

emptySpace = 2; 

} 

distanceBtwnNodes = (int)OPERATORLENGTH/ 

(operators[i] .numberOfInputNodes+1); 
relationHolder = searchForRelation(operators[i].input,i); 
g.drawRect(operators[i].x, operators [i].y, OPERATORLENGTH, 
OPERATORLENGTH/3); 

//operator color 
if (operators[i] .display)} 
g.setColor(Color.red); 

} 

else} 

g.setColor(Color.gray); 

} 

g.fillRect(operators[i].x, operators[i].y, OPERATORLENGTH, 
OPERATORLENGTH/3); 
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//operator name 
g.setColor(Color.black); 

g.drawString(operators[i].name, operators[i].x+emptySpace, operators[i].y+ 
OPERATORLENGTH/5); 


//node input 

for(int xi = 0; xi<operators[i].numberOfInputNodes; xi-H-){ 

String [] tempString = operators[i].getInput(); 

if ((!tempString[xi] .equals("none"))&&( !tempString[xi] .equalsC"))) { 
relatedToOtherOperator = true; 

for (int si = 0; si<relationHolder.size();si-H-) 

{ 

include = (int []) relationHolder.elementAt(si); 
if (xi == include[0]){ 
line(g,xi,i,distanceBtwnNodes,include); 
relatedToOtherOperator = false; 

} 

} 

if (relatedToOtherOperator) 
string(g,xi,i,distanceBtwnNodes); 

) 

} 

//outputNode 

g.fillRoundRect(operators[i].x+OPERATORLENGTH/2, 

operators[i].y+(int)(OPERATORLENGTH/3),5,5,5,5); 

} 


* draws a line from node to other operator or to string 

void line (Graphics g,int xi, int i, int distanceBtwnNodes,int [] include) { 
int xcoord = operators[i].x+(distanceBtwnNodes*(xi+l)+2); 

g.fillRoundRect(operators[i].x+(disteinceBtwnNodes*(xi+l)), 
(operators[i].y - 5),5,5,5,5); 

g.drawLine(xcoord+1 ,operators [i] .y-1, 

operators[include[l]].x+l+OPERATORLENGTH/2, 

operators[include[l]].y+(int)(OPERATORLENGTH/3)); 

} 
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* writes the name of the relation 
**/ 

void string (Graphics g, int xi, int i,int distanceBtwnNodes){ 
int xcoord = operators[i].x+(distanceBtwnNodes*(xi+l)+2); 
int sumx=0; 
float sumy=l; 

g.fillRoundRect(operators [i] .x+(distanceBtwnNodes* (xi+1)), 
(operators[i].y - 5),5,5,5,5); 

if (operators [i] .numberOfInputNodes==4) { 
switch (xi){ 
case 0: 
sumx = -2; 

g.drawString(operators[i].input[xi], (xcoord-40),(operators[i].y - 26)); 
break; 

case 1: 
sumx = -1; 
sumy = 2; 

g.drawString(operators[i].input[xi], (xcoord-25),(operators[i].y - 51)); 
break; 

case 2: 
sumx = 1; 
sumy = L5f; 

g.drawString(operators[i].input[xi], (xcoord-5),(operators[i].y - 38)); 
break; 

case 3: 
sumx = 2; 

g.drawString(operators[i].input[xi], (xcoord+10),(operators[i].y - 26)); 
break; 

} 

} 

else if (operators[i].numberOfInputNodes==3){ 
switch (xi){ 
case 0: 
sumx = -1; 

g.drawString(operators[i].input[xi], (xcoord-40),(operators[i].y - 26)); 
break; 
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case 1: 
sumx = 0; 
sumy = 2; 

g.cirawString(operators[i].input[xi], (xcoord-15),(operators[i].y - 51)); 
break; 

case 2: 
sumx = 1; 

g.drawString(operators[i].input[xi], (xcoord+10),(operators[i].y - 26)); 
break; 

} 

} 

else if (operators [i] .numberOfInputNodes==2) { 
switch (xi){ 
case 0: 
sumx = -1; 

g.drawString(operators[i].input[xi], (xcoord-40),(operators[i].y - 26)); 
break; 
case 1: 
sumx = 1; 

g.drawString(operators[i].input[xi], (xcoord+10),(operators[i].y - 26)); 
break; 

} 

} 

g.drawLine(xcoord,(operators[i].y - 5), 

xcoord+(sumx*10),(operators[i].y - (int)(sumy*25))); 


* creates a new operator and adds it to the array 

public void add(int x, int y, String name, int number. 

String [] input, boolean display. String type. String query) { 

if(numOfOperators<MAXNUMOFOPERATORS) { 
operators[numOfOperators] = new Operator (x,y,name,number, input, 

display, type, query); 

test.window.DFQLQuery.addElement(operators[numOfOperators]); 

numOfOperators-H-; 

repaintO; 

} 
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/** 

* When user double clicks on an operator this method is called and it removes 

* the operator from the operator list. 

**/ 

public void remove(int n){ 
numOfOperators--; 

operators[n] = operators [numOfOperators]; 
if(current == n) 
current = -l; 
repaintQ; 

} 

* main part senses all mouse actions according to the actions 

* conducts different kind of operations: 

* on an empty place; 

* one right click creates a new operator 

* on an operator; 

* one left click, displays the operator information, allows user to change it 

* two right click, deletes the operator 
**/ 

public void mouseClicked(MouseEvent evt){ 
int X = evt.getXO; 
int y = evt.getYO; 

int xBorders = x + OPERATORLENGTH; 
int yBorders = y + OPERATORLENGTH/3; 
int clickCount; 
int number; 

Operator temp; 

current = find(x,y); 

if( levt.isMetaDownO) { 
clickCount = evt.getClickCount(); 

if (current<0){ 

if(test.window.panelOperators.getSelectedIndex()=0){ 

BasicOperators 1 = new BasicOperators(x,y); 

} 

else if(test. window .panelOperators.getSelectedIndex()= 1) { 
AdvancedOperators 1 = new AdvancedOperators(x,y); 

} 
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elseif(test.window.panelOperators.getSelectedIndex()==2){ 
test.window.designRelation = new Vector(); 
test.window.designCondition = new Vector(); 
test, window.design Attribute = new Vector(); 
test.window.designOps = new Vector(); 
test.window.designQueries = new Vector(); 
test.window.setDesign (true); 

UserOperator 1 = new UserOperator(x,y); 

} 

} 

else if (evt.getClickCountO >= 2){ 
for(int bi = 0;bi<test.window.DFQLQuery.size();bi++){ 
temp = (Operator)test.window.DFQLQuery.elementAt(bi); 

if (operators[current] .name.equals(temp.name)) { 
test.window.DFQLQuery.removeElementAt(bi); 

} 

} 

remove (current); 

} 

} 

else{ 

if (current>=0){ 

if (operators[current].type.equals("Select")) { 

number= 0; 

for(int zi = 0;zi<test.window.DFQLQuery.size();zi++){ 
temp = (Operator)test.window.DFQLQuery.elementAt(zi); 
if (operators[current].name.equals(temp.name)){ 
number = zi; 

} 

} 

temp = (Operator)test.window.DFQLQuery.elementAt(number); 

OperatorSelect select = new OperatorSelect(temp.x,temp.y,current, 

number,temp.name, 

temp.input[0], 

temp.input[l], 

temp.display); 

} 

if (operators[current].type.equals("Project")) { 

number= 0; 

for(int zi = 0;zi<test.window.DFQLQuery.size();zi-H-){ 
temp = (Operator)test.window.DFQLQuery.elementAt(zi); 
if (operators[current] .name.equals(temp.name)) { 
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number = zi; 

} 

} 

temp = (Operator)test. window .DFQLQuery.elementAt(number); 

OperatorProject project = new OperatorProject(temp.x,temp.y,current, 

number,temp.name, 

temp.input[0], 

temp.input[l], 

temp.display); 


if (operators[current].type.equals(" Join")) { 

number= 0; 

for(int zi = 0;zi<test. window .DFQLQuery.size();zi++){ 
temp = (Operator)test.window.DFQLQuery.elementAt(zi); 
if (operators[current] .name.equals(temp.name)) { 
number = zi; 

} 

) 

temp = (Operator)test.window.DFQLQuery.elementAt(number); 

OperatorJoin join = new OperatorJoin(temp.x,temp.y,current,number, 

temp.name,temp.input[0], 
temp.input[l], temp.input[2], 
temp.display); 


if (operators[current] .type.equals("Union")) { 
number= 0; 

for(int zi = 0;zi<test. window .DFQLQuery.size();zi-H-){ 
temp = (Operator)test. window .DFQLQuery.elementAt(zi); 
if (operators[current].name.equals(temp.name)){ 
number = zi; 

} 

} 

temp = (Operator)test.window.DFQLQuery.elementAt(number); 

OperatorUnion union = new OperatorUnion(temp.x,temp.y,current,number, 

temp.name,temp.input[0], 
temp.input[l], temp.display); 


if (operators[current] .type.equals("DifF')) { 
number= 0; 

for(int zi = 0;zi<test. window .DFQLQuery.size();zi-H-){ 
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temp = (Operator)test. window .DFQLQuery.elementAt(zi); 
if (operators[current].name.equals(temp.name)){ 
number = zi; 

} 

} 

temp = (Operator)test.window.DFQLQuery.elementAt(number); 

OperatorDiff diff = new OperatorDiff(temp.x,temp.y,current,number, 

temp.name,temp.input[0], 
temp.input[l], temp.input[2], 
temp.display); 


if (operators[current].type.equals("GroupCnt")) { 

number= 0; 

for(int zi = 0;zi<test.window.DFQLQuery.size();zi-H-){ 
temp = (Operator)test.window.DFQLQueiy.elementAt(zi); 
if (operators[current].name.equals(temp.name)){ 
number = zi; 

} 

} 

temp = (Operator)test.window.DFQLQuery.elementAt(number); 

OperatorGroupCnt groupCnt = new OperatorGroupCnt 

(temp.x,temp.y,current, 
number,temp.name, 
temp.input[0], 
temp.input[l], 
temp.input[2], 
temp.display); 

} 

if (operators[current].type.equals("Eqjoin")){ 

number= 0; 

for(int zi = 0;zi<test.window.DFQLQuery.size();zi-H-){ 
temp = (Operator)test.window.DFQLQuery.elementAt(zi); 
if (operators[current] .name.equals(temp.name)) { 
number = zi; 

} 

} 

temp = (Operator)test.window.DFQLQuery.elementAt(number); 

OperatorEqjoin Eqjoin = new OperatorEqjoin 

(temp.x,temp.y,current,number, 
temp.name,temp.input[0], 
temp.input[ 1 ],temp.input[2]. 
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} 


temp.display); 


if (operators[cuiTeiit] .type.equals("GrpAllSat")) { 

number= 0; 

for(int zi = 0;zi<test.window.DFQLQuery.size();zi++){ 
temp = (Operator)test. window .DFQLQuery.elementAt(zi); 
if (operators [current] .name.equals(temp.name)) { 
number = zi; 

} 

} 

temp = (Operator)test.window.DFQLQuery.elementAt(number); 

OperatorGrpAllSat grpAllSat = new OperatorGrpAllSat(temp.x,temp.y, 

current,number, 

temp.name, 

temp.input[0], 

temp.input[l], 

temp.input[2], 

temp.display); 


if (operators[current].type.equals("GrpNSat")){ 

number= 0; 

for(int zi = 0;zi<test.window.DFQLQuery.size();zi++){ 
temp = (Operator)test.window.DFQLQuery.elementAt(zi); 
if (operators[current] .name.equals(temp.name)) { 
number = zi; 

} 

} 

temp = (Operator)test.window.DFQLQuery.elementAt(number); 

OperatorGrpNSat grpNSat = new OperatorGTpNSat(temp.x,temp.y,current, 

number,temp.name, 

temp.input[0], 

temp.input[l], 

temp.input[2], 

temp.input[3], 

temp.display); 


if (operators[current] .type.equals("GrpMax")) { 
numbep= 0; 

for(int zi = 0;zi<test.window.DFQLQuery.size();zi-H-){ 
temp = (C)perator)test.window.DFQLQuery.elementAt(zi); 
if (operators [current] .name.equals(temp.name)) { 
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number = zi; 

} 

} 

temp = (Operator)test. window .DFQLQuery.elementAt(number); 

OperatorGrpMax grpMax = new OperatorGrpMax(temp.x,temp.y,current, 

number,temp.name, 

temp.input[0], 

temp.input[l], 

temp.input[2], 

temp.display); 


if (operators[current].type.equals("GrpMin")){ 

number= 0; 

for(int zi = 0;zi<test.window.DFQLQuery.size();zi-H-){ 
temp = (Operator)test.window.DFQLQuery.elementAt(zi); 
if (operators[current].name.equals(temp.name)){ 
number = zi; 

} 

} 

temp = (Operator)test.window.DFQLQuery.elementAt(number); 

OperatorGrpMin grpMin = new OperatorGrpMin(temp.x,temp.y,current, 

number,temp.name, 

temp.input[0], 

temp.input[l], 

temp.input[2], 

temp.display); 


if (operators[current].type.equals("GrpAvg")){ 

number= 0; 

for(int zi = 0;zi<test.window.DFQLQuery.size();zi++){ 
temp = (Operator)test.window.DFQLQuery.elementAt(zi); 
if (operators[current].name.equals(temp.name)){ 
number = zi; 

} 

} 

temp = (Operator)test.window.DFQLQueiy.elementAt(number); 

OperatorGrpAvg grpAvg = new OperatorGrpAvg(temp.x,temp.y,current, 

number.temp.name, 

temp.input[0], 

temp.input[l], 

temp.input[2], 
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} 


temp.display); 


if (operators [current] .type.equals("Intersect")) { 

number^ 0; 

for(int zi = 0;zi<test.window.DFQLQuery.size();zi-H-){ 
temp = (Operator)test.window.DFQLQuery.elementAt(zi); 
if (operators[current].name.equals(temp.name)){ 
number = zi; 

1 

} 

temp = (Operator)test.window.DFQLQuery.elementAt(number); 

Operatorintersect intersect = new OperatorIntersect(temp.x,temp.y, 

current,number, 

temp.name, 

temp.input[0], 

temp.input[l], 

temp.input[2], 

temp.display); 

} 

} 

} 

} 


* follows mouse movements 

**! 

public void mouseMoved(MouseEvent evt){ 
int X = evt.getXO; 
int y = evt.getY(); 

if (find(x,y) >= 0) 

setCursor(Cursor.getPredefinedCursor( 1)); 
else { 

setCursor(Cursor.getDefaultCursor()); 
current = -1; 

} 

} 


* In order to move the operators. 

* By pressing the right mouse button and dragging the mouse user can move 

* the operator and replace it. 

**! 

public void mouseDragged(MouseEvent evt){ 
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int X = evt.getX(); 

int y = evt.getY(); 

if (current < 0) { 
current = find (x,y); 

} 

if (current >= 0){ 

Graphics g = getGraphics(); 
g. setXORMode(getBackground()); 
operators [current] .X = x; 
operators [current] .y = y; 
g.disposeQ; 
repaintO; 

} 

} 


* deletes all the operators 
public void clear() { 

for(int xi = 0; xi<numOfOperators;xi-H-){ 
operators[xi] = null; 

} 

numOfOperators = 0; 
current = -1; 
repaintO; 

} 


* This method looks for a relation between the operators. 
**/ 

public Vector searchForRelation(String [] input, int i){ 
Vector relationList = new Vector(); 
for(int xi=0;xi<numOfOperators;xi++) { 
for(int yi = 0; yi<operators[i].numberOfIhputNodes;yi-H-){ 
if(input[yi] .equals(operators [xi] .name)) { 
int [] result = {yi,xi}; 
relationList.addElement(result); 

} 

} 

} 

return relationList; 

} 
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* calls the current operator and makes the required changes on it. 

public void change(int index, int indNumber, int x, int y. String name, 
int number. String [] input, boolean display. String type. 
String query)! 
operators [index] .setX(x); 
operators [index]. setY(y); 
operators [index] .setName(name); 
operators [index]. setlnput(input); 
operators[index].setNumberOfInputNodes(number); 
operators[index].setDisplay(display); 
operators [index] .setType(type); 
operators [index] .setQuery(query); 

((Operator)test.window.DFQLQuery.elementAt(indNumber)).setX(x); 

((Operator)test.window.DFQLQuery.elementAt(indNumber)).setY(y); 


((Operator)test.window.DFQLQuery.elementAt(indNumber)).setName(name); 

((Operator)test.window.DFQLQuery.elementAt(indNumber)).setInput(input); 

((Operator)test. window .DFQLQuery.elementAt(indNumber)).setNumberOfInputNodes 

(number); 

((Operator)test. window .DFQLQuery.elementAt(indNumber)).setDisplay(display); 

((Operator)test.window.DFQLQuery.elementAt(indNumber)).setType(type); 

((Operator)test.window.DFQLQuery .element At(indNumber)). setQuery (query); 
repaintO; 

} 

} 

7. Helpjlava 

package ThesisGUI; 

import java.awt.event.*; 
import java.io.*; 
import java.util.*; 
import javax.swing.*; 
import j ava.awt. *; 
import javax.swing.JFrame; 
importjava.net.*; 
import javax.swing.event.*; 
import j ava.lang. *; 
import javax.swing.text.*; 
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!** 

* Displays the user manual 

* 

* AUTHOR : IS & BA 


public class Help extends JFrame implements HyperlinkListenerj 
JEditorPane deneme = new JEditorPane(); 

JScrollPane dene = new JScrollPane(deneme); 

public HelpO { 
try { 
jblnitO; 

} 

catchOException e) { 

System.out.println(e.getMessage()); 

} 

} 

private void jblnit() throws Exception { 
this.setTitleC'User Manual for DFQL application"); 
deneme.setEditable(false); 
this.getContentPane().add(dene,null); 
setBounds(100,100,400,300); 

try { 

deneme.setPage 

("file:///"+test.window.getProgramPath()+"/manual/index.html"); 

deneme.setCursor 

(Cursor.getPredefinedCursor(Cursor.DEFAULT_CURSOR)); 

deneme.addHyperlinkListener(this); 

} 

catch (MalformedURLException ed){ 
System.out.println(ed.getMessage()); 

} 

catch (lOException e){ 

System.out.println(e.getMessage()); 

} 

show(true); 


public void hyperlinkUpdate( HyperlinkEvent event){ 

if( event. getEventTypeO == HyperlinkEvent-EventType. ACTIVATED){ 
// Lxjad some cursors 
Cursor cursor = deneme.getCursor(); 
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Cursor waitCursor = Cursor.getPredefinedCursor 
(Cursor.WAir.CURSOR); 
deneme.setCursor(waitCursor); 


// Handle the hyperlink change 
SwingUtilities.invokeLater( new PageLoader(deneme, 

event.getURL(), cursor)); 


} 

else if (event.getEventType() == HyperlinkEvent.EventType. 

ENTERED){ 

// Load some cursors 

Cursor linkCursor = Cursor.getPredefinedCursor( 
Cursor.HAND_CURSOR); 
deneme.setCursor(linkCursor); 

} 


else if( event.getEventType() == HyperlinkEvent.EventType.EXITED){ 
// Load some cursors 

Cursor defCursor = Cursor .getPredefinedCursor( 

Cursor.DEFAULT_CURSOR); 
deneme.setCursor(defCursor); 

} 

} 


class PageLoader implements Runnable { 
private JEditorPane html; 
private URL url; 
private Cursor cursor; 

PageLoader( JEditorPane html, URL url, Cursor cursor){ 
this.html = html; 
this.url = url; 
this.cursor = cursor; 

} 


public void run(){ 
if( url == null){ 

// restore the original cursor 
html.setCursor( cursor ); 

} 

else { 

Document doc = html.getDocument(); 
try { 

html.setPage( url); 

} 

catch( lOException ioe){ 
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htinl.setDocument( doc); 

) 

catch (NullPointerException deded){ 

System.out.println(deded.getMessage()); 

} 

finally { 

// schedule the cursor to revert after 
// the paint has happended. 
url = null; 

SwingUtilities.invokeLater( this); 

} 

} 

} 

} 

} 

Logonjava 

package ThesisGUI; 

import java.awt.*; 
import j avax. swing. *; 
import java.awt.event.*; 
import java.sql.*; 
import java.io.*; 
import java.util.*; 
import j ava.util.Vector; 
import j avax.accessibility.*; 
import javax.swing.UIManager; 

j** 

* This frame is used to connect to a database. It allows user to enter 

* the required information (url, driver, username, password) and according to 

* the information entered, it creates a database object. When this class first 

* called default values for a local student database are displayed. 

* 

* AUTHOR: IS & BA 

public class Logon extends JFrame { 

/** Label user name**/ 

JLabel IblUserName = new JLabel(); 

/** Label password**/ 

JLabel IblPassword = new JLabel(); 

100 




/** Label url**/ 

JLabel IblURL = new JLabel(); 

/** Label driver**/ 

JLabel IblDriver = new JLabel(); 

/** Text field user name, where the user enters his/her name**/ 
JTextField txtUserName = new JTextFieldQ; 

/** Text field password, where the user enters his/her password**/ 
JTextField txtPassword = new JTextField(); 

/** Text field user name, where the user enters database's url**/ 
JTextField txtURL = new JTextField(); 

/** Text field user name, where the user enters database's driver**/ 
JT extField txtDri ver = new JTextFieldO; 

/** Cancel button**/ 

JButton btnCancel = new JButton(); 

/** Okay button**/ 

JButton bmOK = new JButtonQ; 

/** A database object encapsulates the functionalities provided the 

* Connection, Statement, and other JDBC classes 

* @see Database 
**/ 

Database database; 


* The connection info of the database 

* @see Databaseinfo 
**! 

Databaseinfo databaseinfo; 

/* CONSTRUCTOR */ 

!** 

* The constractor 

public Logon() { 
try { 
jblnitO; 

} 

catch(Exception e) { 
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e.printStackTraceO; 

} 

} 


/* INITIATE METHOD */ 

* The initiation 

* creates the frame, and the buttons. Initiates them, 
private void jblnit() throws Exception { 


this.setTitle 

IblU serN ame. setText 

btnCancel. setText 

lblPassword.setText 

IblURL.setText 

IblDriver. setText 

btnOK.setText 

txtUserName.setText 

txtPassword. setText 

txtURL.setText 

txtDriver.setText 


("Enter connection information"); 

("User Name 

("Cancel"); 

("Password:"); 

("Database URL:"); 

("Driver:"); 

("OK"); 

("anonymous"); 

("guest"); . . 

("jdbc:odbc:studentdbl"); 

("sun.jdbc.odbcJdbcOdbcDriver"); 


IblU serN ame. setBounds 

IblPassword.setBounds 

IblURL.setBounds 

IblDriver. setBounds 

txtU serN ame. setBounds 

txtPassword-setBounds 

txtURL.setBounds 

txtDriver.setBounds 

btnCancel. setB ounds 

btnOK.setBounds 


(new Rectangle(8, 16, 106,19)); 
(new Rectangle(8,41,106,19)); 
(new Rectangle(8, 65,106,19)); 
(new Rectangle(8, 90,106,19)); 
(new Rectangle(113, 15,196, 21)); 
(new Rectangle(l 13,40,196, 21)); 
(new Rectangle(l 13,64,196,21)); 
(new Rectangle(l 13, 89,196, 21)); 
(new Rectangle(8, 119,146,18)); 
(newRectangle(163,119,146,18)); 


btnCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnCancel_actionPerformed(e); 

}}); 


bmOK.addActionListener (new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnOK_actionPerformed(e); 

}}); 

this.getContentPane().setLayout(null); 
this.getContentPane(Xadd(lblUserName, null); 
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this.getContentPane().add(txtUserName, null); 
this.getContentPane().add(lblPassword, null); 
this.getContentPane().add(lblURL, null); 
this.getContentPane().add(lblDriver, null); 
this.getContentPaneO .add(txtPassword, null); 
this.getContentPane().add(txtURL, null); 
this.getContentPane().add(btnOK, null); 
this.getContentPane().add(btnCancel, null); 
this.getContentPaneO. add(txtDri ver, null); 
setBounds(350,200,330,180); 
show(trae); 

} 


* The Cancel button action performed 

* Terminates this frame without connecting to a database 

void btnCancel_actionPerformed(ActionEvent e) { 
this.disposeO; 

} 


/** 

* The Okay button action performed 

* When this button is pressed, it creates a databaseinfo object, 

* sets its values with the entered information, 

* according to the database info creates a database object, 

* connects to this database, 

* adds this database object to the active database list, 

* modifies the tree, 

* gives a connected message to the user 

* if the connection can not be established gives an error message 
**! 

void btnOK_actionPerformed(ActionEvent e) { 

databaseinfo = new DatabaseInfo(); 
databaseInfo.setUserid (txtUserName.getTextO); 
databaseLifo.setPassword(txtPassword.getText()); 
databaselnfo.setDriver (txtDriver.getTextO); 
databasehifo.setURL (txtURL.getText()); 
try{ 

database = new Database (databaseinfo); 
database.connectO; 

test.window.databaseList. add (database); 
test, window .currentDatabase = database; 
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test.window.generateTreeO; 

test.window.setTitle(database.getURL()); 

test.window.panelMain.setEnabled(true); 

test.window.message.setMessageC'Connected :" + database.getURL()); 
test.window.message.show (true); 

} 

catch (ClassNotFoundException ey){ 
database = null; 

test.window.message.setMessage ("not connected... "+ey.getMessage()); 
test.window.message.show (trae); 

} 

catch (SQUException ex){ 
database = null; 

test.window.message.setMessage ("not connected... "+ex.getMessage()); 
test.window.message.show (trae); 

} 

this.disposeO; 

} 

} 

9. MainTestJava 

package ThesisGTJI; 

import java.awt.event.*; 
import java.io.*; 
import java.util.*; 
import java.awt.*; 
import javax.swing.*; 
import java.sql.*; 
import java.util. Vector; 
import javax.accessibility.*; 
import javax.swing.UIManager; 
import javax.swing.tree.*; 
import javax.swing.event.*; 
import j ava.beans. *; 

* This is the main frame 

* It is a user interface, which allows us to make connections to the databases, 

* see these database informations, write SQL queries or create DFQL queries, 

* execute these queries and display results. 

* It has three different part, first (west) is a scroll panel+text area 

* is used to display the meta data, second (north east) is tabpahel 

* has four different panels, one is text area for SQL statement, one 
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* is a canvas for DFQL statement, and two text areas for database information 

* and last one (south east) is a scroll panel+text area is used to display 

* results of queries 

* 

* AUTHOR : BA & IS 

**! 

public class MainTest extends JFrame implements WindowListener{ 

/** Counter for each operator **/ 

protected int [] Counter = {1,1,1,1,1,1,1,1,1,1,1,1,1}; 

/** It is the canvas on which we draw our operators **/ 
protected Draw cnvDFQL = new Draw(); 

/** Holds the databases that we connected **/ 
protected Vector databaseList = new Vector(); 

/** Displays warning, information, error and exception messages **/ 
protected Message message = new Message (); 

/** Ensures the relation with the database results and result table **/ 
protected Relation relation = new Relation(); 

/** Used to display the table information when clicked on it **/ 
protected Relation relationTable = new Relation(); 

/** Holds the operators that we created **/ 
protected Vector DFQLQuery = new Vector(); 

/** Query that we created **/ 
protected String sqlQuery; 

/** Active database connection **/ 
protected Database currentDatabase; 

/** Displays the user manual **/ 
protected Help help; 

/** Temporary variable database type **/ 
protected Database tempDatabase; 

/** Temporary variable Operator type **! 
protected Operator tempOperator; 

/** Counter used for displaying each operator in order **/ 
protected int index; 
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/** Counter used for connecting to each database in order**/ 
protected int indexDatabase; 

/** holds the active panel information (SQL, DFQL, Definition, Data) **/ 
protected int indexPanel= 0; 

/** Height of the main frame **/ 
private static final int HEIGHT = 600; 

/** Width of the main frame **/ 
private static final int WIDTH =800; 

private final String path = System.getProperty("user.dir"); 

/** Used to display database information **/ 

JTree treeMeta = new JTree(); 

/** Main (Tabbed) panel contains 4 tabs **/ 

JTabbedPane panelMain = new JTabbedPane(); 

/** This (Tabbed) panel for operators contains 3 tabs **/ 

JTabbedPane panelOperators = new JTabbedPane(); 

/** This panel holds the tree meta, it is used to display database info **/ 
JScrollPane panelMeta = new JScrollPane(treeMeta); 

/**This panel holds the DFQL query design area**/ 

JscrollPane denememe = new JScrollPane (); 

/**This table is used to display sql and dfql queries results **/ 

JTable SQLResult = new JTable(relation); 

/** This table is used to display database table info **/ 

JTable tableData = new JTable(relationTable); 

/** Scroll panel holds the SQLResults table **/ 

JScrollPane panelResults = new JScrollPane(SQLResult); 

/** Scroll panel holds the tableData table **/ 

JScrollPane panelTableData = new JScrollPane(tableData); 

/** When using DFQL, this button allows user to execute the nest operator and 
* display its results. **/ 

JButton btnNextl = new JButtonf'NEXT OPERATOR"); 
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/** When working with multiple databases, this button allows user to change the 
database that the query will be executed **/ 

JButton btnNext2 = new JButton("NEXT DATABASE"); 

/** Text area allows user to enter sql queries **/ 

JTextArea txtSQL = new JTextArea(); 

/** This text area is called definition area. Displays the details of database 
* and attribute information **/ 

JTextArea metaData = new JTextAreaQ; 

/** TTiis image icon is used to place the images of the program **/ 

Imagelcon icon; 

//toolBasic 

/** Toolbar for basic operators **/ 

JToolBar toolBasic = new JToolBar(); 

/** Operator select button **/ 

JButton btnSelect = new JButton (" Select "); 

/** Operator project button **/ 

JButton btnProject = new JButton (" Project "); 

/** Operator join button **/ 

JButton btnJoin = new JButton (" Join "); 

/** Operator union button **/ 

JButton btnUnion = new JButton (" Union "); 

/** Operator different button **/ 

JButton btnDiff = new JButton (" Diff "); 

/** Operator group count button **/ 

JButton btnGroupCnt = new JButton (" Groupcnt "); 

//toolAdvance 

/** Toolbar for advance operators **/ 

JToolBar toolAdvance = new JToolBarQ; 

/** Operator Eqjoin button **/ 

JButton btnEqjoin = new JButton (" Eqjoin "); 

/** Operator group all satisfy button **/ 

JButton btnGrpAllSat = new JButton ("GrpAllsat"); 
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/** Operator group number satisfy button **/ 
JButton btnGrpNSat = new JButton (" GrpNsat"); 

/** Operator group maximum button **/ 

JButton btnGrpMax = new JButton (" GrpMax "); 

!** Operator group minimum button **/ 

JButton btnGrpMin = new JButton (" GrpMin "); 

!** Operator group average button **/ 

JButton btnGrpAvg = new JButton (" GrpAvg "); 

/** Operator intersect button **/ 

JButton btnintersect = new JButton (" Intersect"); 

//toolUserDefined 

!** Toolbar for user defined operators **/ 

JToolBar toolUserl = new JToolBar(); 


/** Operator User button **/ 

JButton userNew = new JButton ("New"); 

Loads saved user operator button **l 
JButton userLoad = new JButton ("Load"); 

//toolBar 

/** Toolbar for program tools **/ 

JToolBar toolBar = new JToolBar(); 

/** Exit button terminates program **/ 

JButton btnExit; 

/** Print button prints the query results **/ 

JButton btnPrint; 

/** Connect button connects to database **/ 

JButton btnConnect; 

/** Disconnect button disconnects from the database **/ 
JButton btnDisConnect; 

/** SQL execute button, executes the SQL query **/ 
JButton btnSQLExecute; 
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/** New button, clears all the windows **/ 

JButton btnNew; 

/** Save button, allows user to save the DFQL operator that is created **/ 
JButton btnSave; 

!** Open button, allows user to load previously saved operator **/ 

JButton btnOpen; 

/** DFQL execute button executes the query produced by dfql operators **/ 
JButton btnDFQLExecute; 

/** Manual button, displays the user manual for the program **/ 

JButton btnManual; 

/** Send all button, executes the query with all of the databases connected **/ 
JButton bmSendAll; 

//Menu 

/** Pull down menu for program tools **/ 

JMenuBar menuBar; 

/** File menu (Exit, print) **/ 

JMenu menuFile; 

/** Exit menu item **/ 

JMenuItem menuFileExit; 

/** Print menu item **/ 

JMenuItem menuFilePrint; 

/** Connection menu (connect, disconnect) **/ 

JMenu menuConnection; 

/** Connect menu item **/ 

JMenuItem menuConnectionConnect; 

/** Disconnect menu item **/ 

JMenuItem menuConnectionDisConnect; 

/** SQL menu (SQLExecute) **/ 

JMenu menuSQL; 

/** SQLExecute menu item **/ 

JMenuItem menuSQLExecute; 
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/** DFQL menu (new, save, open, DFQLExecute) **/ 
JMenu menuDFQL; 

/** New menu item **/ 

JMenuItem menuDFQLNew; 

/** Save menu item **/ 

JMenuItem menuDFQLSave; 

/** Open menu item **/ 

JMenuItem menuDFQLOpen; 

/** DFQLExecute menu item **/ 

JMenuItem menuDFQLExecute; 

/** Help menu (manual) **/ 

JMenu menuHelp; 

/** Manual menu item **/ 

JMenuItem menuHelpManual; 

JMenuItem menuSettings = new JMenuItem(); 

/** User defined operator vectors**/ 
boolean design; 

Vector designRelation; 

Vector designCondition; 

Vector designAttribute; 

Vector designOps; 

Vector designQueries; 

/* CONSTRUCTOR */ 

/** 

* The constructor 
**/ 

public MainTestO { 
try { 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 
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/* INITIATE METHOD */ 

!** 

* The initiation 

* creates the mainframe, panels, buttons, text areas, menu items and 

* tables, and initiates them. 

private void jblnit() throws Exception { 
addWindowListener (this); 
this.setSize (WIDTH, HEIGHT); 
this.setTitle ("No Current Database Connection"); 


j ^ 

//ToolBar; Program tools 

j ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ 


toolBar.setBounds(new Rectangle(10, 15, (int)(WIDTH/10), 
(int)(HEIGHT*21/24))); 
toolB ar. setLayout(null); 

icon = new Imagelcon (path+"\\images\\exit.gif',"Exit"); 
btnExit = new JButton(icon); 
btnExit.setT oolT ipT ext("Exit"); 

btnExit-setBounds (new Rectangle (10,10,(int)(WIDTH/16), 
(int)(HEIGHT/15))); 

btnExit.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnExit_actionPerformed(e); 

}}); 

btnExit.setHorizontalAlignment (SwingConstants.CENTER); 
btnExit.setVerticalAlignment (SwingConstants.TOP); 

icon = new Imagelcon (path+"\\images\\print.gif',"Print"); 
btnPrint = new JButton(icon); 
btnPrint.setToolTipText("Print"); 

btnPrint.setBounds(new Rectangle( 10,((int)(HEIGHT/l 5)+l 5), 
(int)(WIDTH/16),(int)(HEIGHT/15))); 

btnPrint.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnPrint_actionPerformed(e); 

}}); 

btnPrint.setHorizontalAlignment (SwingConstants.CENTER); 
btnPrint.setVerticalAlignment (SwingConstants.CENTER); 

icon = new Imagelcon (path+"\\images\\connect.gif',"Connect"); 
btnConnect = new JButton(icon); 
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btnConnect.setTooITipText("Connect"); 
btnConnect.setBounds(newRectangle(10,2*(int)(HEIGHT/15)+20, 
(int)(WIDTH/16), (int)(PffiIGHT/15))); 
btnConnect.addActionListener(new java.awt.event.ActionListenerQ { 
public void actionPerformed(ActionEvent e) { 
btnConnect_actionPerformed(e); 

}}); 

btuConnect-setHorizontalAlignment (SwingConstants.CENTER); 
btnConnect.setVerticalAlignment (SwingConstants.CENTER); 

icon = new Imagelcon (path+"\\images\\disconnect.gif'/'Disconnect"); 

btnDisConnect = new JButton(icon); 
btnDisConnect.setToolTipText("Disconnect"); 
btnDisConnect.setBounds(new Rectangle(10,3*(int)(HEIGHT/15)+25, 

(int)(WIDTH/16),(int)(HEIGHT/15))); 
btnDisConnect.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerfomied(ActionEvent e) { 
btnDisConnect_actionPerfomied(e); 

}}); 

btnDisConnect.setHorizontalAlignment (SwingConstants.CENTER); 
btnDisConnect.setVerticalAlignment (SwingConstants.CENTER); 

btnSQLExecute = new JButton("!"); 

btnSQLExecute.setFont(new java.awt.Font("Dialog", 1 , 36)); 

btnSQLExecute.setForeground(Color.red); 

btnSQLExecute.setToolTipText("SQLExecute"); 

btnSQLExecute.setBounds(newRectangle( 10 , 4 *(int)(HEIGHT/ 15 )+ 30 , 

(int)(WIDTH/16),(int)(HEIGHT/15))); 
btnSQLExecute.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerfomied(ActionEvent e) { 
btnSQLExecute_actionPerformed(e); 

}}); 

icon = new Imagelcon (path+"\\images\\New.gif'/'New"); 
btnNew = new JButton(icon); 
btnNew.setToolTipTextC'New"); 

btnNew.setBounds(new Rectangle( 10,5*(int)(HEIGHT/l 5)+35, 
(int)(WlDTH/16),(int)(HEIGHT/15))); 
btnNew.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnNew_actionPerformed(e); 

}}); 

btnNew.setHorizontalAlignment (SwingConstants.CENTER); 
btnNew.setVerticalAlignment (SwingConstants.CENTER); 

icon = new Imagelcon (path+"\\images\\Save.gif'/'Save"); 
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btnSave = new JButton(icon); 
btnSave.setToolTipTextC'Save"); 

btnSave.setBounds(new Rectangle( 10,7*(int)(HEIGHT/15), 
(int)(WIDTH/16),(int)(HEIGHT/15))); 
btnSave.addActionListener(new java.awt.event.ActionListenerQ { 
public void actionPerformed(ActionEvent e) { 
btnSave_actionPerfonned(e); 

}}); 

btnSave.setHorizontalAlignment (SwingConstants.CENTER); 
btnSave.setVerticalAlignment (SwingConstants.CENTER); 

icon = new Imagelcon (path+"\\images\\open.gif'."Open"); 
btnOpen = new JButton(icon); 
btnOpen.setToolTipText("Open"); 

btnOpen.setBounds(new Rectangle(10,8*(int)(HEIGHT/15)+5, 
(int)(WIDTH/16),(int)(HEIGHT/15))); 
btnOpen.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnOpen_actionPerformed(e); 

}}); 

btnOpen.setHorizontalAlignment (SwingConstants.CENTER); 
btnOpen.setVerticalAlignment (SwingConstants.CENTER); 

btnDFQLExecute = new JButton("!"); 
btnDFQLExecute.setFont(new java.awt.Font("Dialog", 1,36)); 
btnDFQLExecute.setForeground(Color.blue); 
btnDFQLExecute.setToolTipTextC'DFQLExecute"); 
btnDFQLExecute.setBounds(new Rectangle(10,9*(int)(HEIGHT/15)+10, 

(int)(WIDTH/16),(int)(HEIGHT/15))); 
btnDFQLExecute.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnDFQLExecute_actionPerfomied(e); 

}}); 

icon = new Imagelcon (path+"\\images\\About.gif'."About"); 
btnManual = new JButton(icon); 
btnManual.setToolTipTextC'Manual"); 

btnManual. setBounds(new Rectangle( 10.10* (int)(HEIGHT/15)+15. 

(int)(WIDTH/16),(int)(HEIGHT/l 5))); 
btnManual.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnManual_actionPerfonned(e); 

}}); 

btnManual.setHorizontalAlignment (SwingConstants.CENTER); 
btnManual.setVerticalAlignment (SwingConstants.CENTER); 
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icon = new Lnagelcon (path+"\\images\\sendAlLgif'."SendAll"); 
btnSendAll = new JButton(icon); 
btnSendAll.setToolTipText("Send to all databases"); 
btnSendAll.setBounds(new Rectangle(10,l l*(int)(HEIGHT/15)+20, 

(int)(WlDTH/16),(int)(HEIGHT/15))); 
btnSendAlLaddActionListener(new java.awt.event.ActionListenerQ { 
public void actionPerformed(ActionEvent e) { 
btnSendAll_actionPerformed(e); 

}}); 

btnSendAll.setHorizontalAlignment (SwingConstants.CENTER); 
btnSendAll.setVerticalAlignment (SwingConstants.CENTER); 

txtSQL.addComponentListener(newjava.awt.event.ComponentAdapter() { 
public void componentShown(ComponentEvent e) { 
txtSQL_componentShown(e); 

}}); 

metaData.addComponentListener(new java.awt.event.ComponentAdapter() { 
public void componentShown(ComponentEvent e) { 
metaData_componentShown(e); 

}}); 

panelTableData.addComponentListener(new 
java.awt.event.ComponentAdapter() { 
public void componentShown(ComponentEvent e) { 
panelT ableData_componentShown(e); 

}}); 

denenieme.getViewport().add(cnvDFQL); 

denememe.addComponentListener(new java.awt.event.ComponentAdapter() { 
public void componentShown(ConiponentEvent e) { 
denememe_componentShown(e); 

}}); 

txtSQL.setNextFocusableComponent(cnvDFQL); 
txtSQL.setLineWrap(trae); 
menuSettings.setTextC'Settings..."); 

menuSettings.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerfonned(ActionEvent e) { 
menuSettings_actionPerformed(e); 

}}); 

toolB ar.add(btnExit); 

toolBar.add(btnManual); 

toolBar.add(btnSendAll); 
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toolBar.add(btnPrint); 
toolBar.add(btnConnect); 
toolBar.add(btnDisConnect); 
toolB ar.add(btnNew); 
toolB ar. add(btnS ave); 
toolB ar.add(btnOpen); 
toolB ar.add(btnSQLExecute); 
toolB ar. add(btnDFQLExecute); 

//End ToolBar 

//Next Buttons 

btnNextl.setToolTipTextC'dispalys next operatorVs results"); 
btnNext2.setToolTipText("dispalys next databaseVs results"); 

btnNextl.setBounds(new Rectangle((int)(WIDTH/10)+ 
10,2*(int)(HEIGHT*5/13)+17, 
(int)(WIDTH*5/l 6),20)); 

btnNext2.setBounds(newRectangle((int)(WIDTH/10)+ 

10,2*(int)(HEIGHT*5/13)+39, 

(int)(WIDTH*5/16),20)); 

btnNextl .setEnabled(false); 

btnNext 1 .addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnNext 1 _actionPerformed(e); 

}}); 

btnNext2.setEnabled(false); 

btnNext2.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnNext2_actionPerformed(e); 

}}); 


//************ ***********************:*:************************* ********* 

//End Next Buttons 

^^^:i«:f:*:ic:l:**5i:4:5i:5l::i:********************************************************* 
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//Menu 

//**:ic*****H:****5i:5f:**5i:******5f:***2f:*****5i:H:HJ ********************************* 


7/Menu File 
menuFile 
menuFileExit 
menuFilePrint 


= new JMenu ("File"); 

= new JMenuItem ("Exit"); 
= new JMenuItem ("Print"); 


menuFileExit.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
menuFileExit_actionPerformed(e); 

}}); 


menuFilePrint.addActionListener(newjava.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
menuFilePrint_actionPerformed(e); 

}}); 

menuFile.add(menuFileExit); 

menuFile.add(menuFilePrint); 

//Menu Connection 

menuConnection = new JMenu ("Connection"); 

menuConnectionConnect = new JMenuItem ("Connect"); 

menuConnectionDisConnect = new JMenuItem ("Disconnect"); 

menuConnectionConnect.addActionListener(new 
java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
menuConnectionConnect_actionPerformed(e); 

}}); 

menuConnectionDisConnect.addActionListener(new 
java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
menuConnectionDisConnect_actionPerfonned(e); 

}}); 

menuConnection.add(menuConnectionConnect); 

menuConnection.add(menuConnectionDisConnect); 

menuConnection.add(menuSettings); 

//Menu SQL 

menuSQL , = new JMenu ("SQL"); 
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menuSQLExecute = new JMenuItem ("Execute"); 


inenuSQLExecute.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerfonned(ActionEvent e) { 
menuSQLExecute_actionPerformed(e); 

}}); 

menuSQL.add(menuSQLExecute); 


//Menu DFQL 

menuDFQL 

menuDFQLNew 

menuDFQLSave 

menuDFQLOpen 

menuDFQLExecute 


= newJMenu ("DFQL"); 

= new JMenuItem ("New"); 

= new JMenuItem ("Save"); 

= new JMenuItem ("Load"); 

= new JMenuItem ("Execute"); 


menuDFQLNew.addActionListener(new java.awt.event.ActionListener(){ 
public void actionPerformed(ActionEvent e) { 
menuDFQlJ^ew_actionPerformed(e); 

}}); 


menuDFQLSave.addActionListener(new java.awt.event.ActionListener(){ 
public void actionPerformed(ActionEvent e) { 
menuDFQLSave_actionPerformed(e); 

}}); 


menuDFQLOpen.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
menuDFQLOpen_actionPerformed(e); 

}}); 

menuDFQLExecute.addActionListener(newjava.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
menuDFQLExecute_actionPerformed(e); 

}}); 

menuDFQL.add(menuDFQLJ^ew); 
menuDFQL.add(menuDFQLSave); 
menuDFQL.add(menuDFQLOpen); 
menuDFQL.addSeparatorO; 
menuDFQL.add(menuDFQLExecute); 

//Menu Help 

menuHelp = new JMenu ("Help"); 

menuHelpManual = new JMenuItem ("Manual"); 
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menuHelpManual.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
menuHelpManual_actionPerformed(e); 

}}); 

menuHelp.add(menuHelpManual); 

//Adding menubar 

menuBar = new JMenuBarQ; 

menuBar.add(menuFile); 

menuBar. add(menuConnection); 

menuBar.add(menuSQL); 

menuBar.add(menuDFQL); 

menuBar.add(menuHelp); 


//End menu 


//Operator Tool Bar 


//toolBasic 

toolBasic.setBounds((int)(WIDTH*33/80)+20,(int)(HEIGHT*ll/15)+16, 
(int)(WIDTH/80*43),(int)(HEIGHT/10)-5); 
btnSelect.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnSelect_actionPerformed(e); 

}}); 

bmProject.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnProject_actionPerformed(e); 

}}); 

bmJoin.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnJoin_actionPerformed(e); 

}}); 

btnUnion.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnUnion_actionPeiformed(e); 

}}); 
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btnDiff.addActionListener(new java.awt.event.ActionListenerQ { 
public void actionPerformed(ActionEvent e) { 
btnDiff_actionPerfonned(e); 

}}); 

btnGroupCnt.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnGTOupCnt_actionPerfonned(e); 

}}); 

toolBasic.add(btnSelect); 

toolB asic. add(btnProject); 

toolBasic.add(btnJoin); 

toolBasic.add(btnUnion); 

toolBasic.add(btiiDiff); 

toolBasic.add(btnGroupCnt); 

//toolAdvance 

toolAdvance.setBounds((int)(W]DTH*33/80)+20,(int)(HEIGHT*ll/15)+16, 

(int)(WIDTH/80*43),(int)(HEIGHT/10)-5); 


btnEqjoin.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerfonned(ActionEvent e) { 
btnEqjoin_actionPerformed(e); 

}}); 

btnGrpAllSat.addActionListener(new java.awt.event.ActionListenerQ { 
public void actionPerformed(ActionEvent e) { 
btnGrpAllSat_actionPerformed(e); 

}}); 

btnGrpNSat.addActionListener(new java.awt.event.ActionListenerQ { 
public void actionPerformed(ActionEvent e) { 
btnGrpNSat_actionPerfonned(e); 

}}); 

btnGrpMax.addActionListener(new java.awt.event.ActionListenerQ { 
public void actionPerformed(ActionEvent e) { 
btnGrpMax_actionPerf6rmed(e); 

}}); 

btnGrpMin.addActionListener(new java.awt.event.ActionListenerQ { 
public void actionPerformed(ActionEvent e) { 
btnGrpMin_actionPerformed(e); 

}}); 
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btnGrpAvg.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnGrp Avg_actionPerformed(e); 

}}); 

btnIntersect.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnIntersect_actionPerformed(e); 

}}); 

toolAdvance.add(btnEqjoin); 

toolAdvance.add(btnGrpAllSat); 

toolAdvance.add(btnGipNSat); 

toolAdvance.add(btnGrpMax); 

toolAdvance.add(btnGrpMin); 

tool Advance.add(btnGrpAvg); 

tool Advance.add(btnLitersect); 

//toolUserl 

toolUserl .setBounds((mt)(WIDTH*33/80)+20,(int)(HEIGHT* 11/15)+16, 

(int)(WIDTH/80*43),(int)(HEIGHT/10)-5); 

userNew.addActionListener(new java.awt.event.ActionListenerQ { 
public void actionPerformed(ActionEvent e) { 
userNew_actionPerformed(e); 

}}); 

userLoad.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
userLx)ad_actionPerfonned(e); 

}}); 

toolUserl .add(userNew); 
toolUserl .add(userLoad); 


//End Operators tool bar 

ijc 5f: i}: Pf! * ^ :ic 4: * * Ji:* 3!c :ic :ic :i: ^He^^ :jc ^ :ie ^ :jc ^ 4: sie * ^ :ie :i: 4: ^ ^ :ic ^ 


//General configuration 

^yHi*********5l;HJ**if:*5i:*****H«iiiH:** *********5*: sKHs ************** 


// color 

cnvDFQL.setB ackground (SystemColor.info); 
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txtSQL.setBackground (Color.black); 
txtSQL.setForeground (Color, white); 
metaData.setBackground (Color.pink); 

// enable / editable 
metaData-setEditable (false); 
panelOperators.setVisible (false); 
panelMain.setEnabled (false); 

this.setTMenuBar (menuBar); 

metaData-setFont (new java.awt.Font("Monospaced", 1,12)); 

SQLResult.setAutoResizeMode (JTable.AUTO_RESIZE_OFF); 
treeMeta-addTreeSelectionListener (new DBSelectionListenerO); 
treeMeta-setModel (null); 

panelMain.add (txtSQL, "SQL"); 
panelMain.add (cnvDFQL, "DFQL"); 
panelMain.add (metaData, "Definition"); 
panelMain.add (panelTableData, "Data"); 

panelOperators.add (toolBasic, "Basic"); 
panelOperators.add (toolAdvance,"Advance"); 
panelOperators.add (toolUserl,"User-Defined"); 

panelMain.setBounds(new Rectangle((int)(WIDTH*33/80)+20,10, 

(int)(WIDTH/80*43), 
(int)(HEIGHT* 11/15)+6)); 

panelOperators.setBounds(new Rectangle ((int)(WIDTH*33/80)+20, 

(int)(HEIGHT*ll/15)+16, 

(int)(WIDTH/80*43), 

(int)(HEIGHT/10))); 

panelMeta.setBounds(new Rectangle((int)(W]DTF[/10)-i-10,15, 

(int)(WlDTH*5/16), 

(int)(HEIGHT*5/13))); 

panelResults.setBounds(newRectangle((int)(WlDTH/10)+10, 

(int)(HEIGHT*5/13)-i-16, 

(int)(WIDTH*5/16), 

(int)(HEIGHT*5/13))); 

this.getContentPane().add(toolBar, null); 
this.getContentPane().add(panelMeta); 
this.getContentPaneO. add(panelResults, null); 
this.getContentPane().add(panelMain, null); 
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this.getContentPane().add(panelOperators,null); 

this.getContentPane0.add(btnNextl,null); 

this.getContentPane().add(btnNext2,null); 

this.getContentPane().setLayout(null); 

panelMain.setSelectedlndex(O); 

generateTreeO; 

design = false; 

} 



WINDOW ACTIVATIONS 


*/ 


* The window listener methods 

* @param event (WindowEvent) 

public void windowClosing 
public void window Activated 
public void windowClosed 
public void windowDeactivated 
public void windowDeiconified 
public void windowiconified 
public void windowOpened 


(WindowEvent event) {System.exit(0);} 
(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 


/* MENU ACTION PERFORMED */ 

* Exit menu action performed 

* @param e (ActionEvent) 

**! 

void menuFileExit_actionPerfonned(ActionEvent e) { 
System.exit(l); 

} 


!** 

* Print menu action performed 

* @param e (ActionEvent) 

**! 

void menuFilePrint_actionPerformed(ActionEvent e) { 
printO; 

} 


/** 

* Manual menu action performed 

* @param e (ActionEvent) 

**/ 

void menuHelpManual_actionPerformed(ActionEvent e) { 
help = new Help(); 

} 
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/** 

* Connect menu action performed 

* @param e (ActionEvent) 

**/ 

void connect(){ 

Logon logon = new LogonQ; 

} 


* Disconnect menu action performed 

* @param e (ActionEvent) 

**/ 

void disconnect(){ 
if (databaseList.sizeO != 0){ 

try { 

databaseList.removeElement(currentDatabase); 

String oldURL = currentDatabase.getURL(); 
currentDatabase.disconnectO; 

if (databaseList.size() != 0){ 

currentDatabase = (Database) databaseList.lastElement(); 
this.setTitle(currentDatabase.getURL()); 

} 

else { 

currentDatabase = null; 

this.setTitleC'No Current Database Connection"); 

panelMain.setEnabled(false); 

panelOperators.setVisible(false); 

metaData.setText(" "); 

relation.clearO; 

clear(); 

} 

generateTreeO; 

message.setMessage("disconnected:" + oldURL); 
message.show(tme); 

} 

catch (SQLException e) { 
message.setMessage(e.getMessage()); 
message.show(trae); 

} 

} 

} 
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* Connect menu action performed 

* @param e (ActionEvent) 

**/ 

void menuConnectionConnect_actionPerformed(ActionEvent e) { 
connectO; 

} 


/** 

* Disconnect menu action performed 

* @param e (ActionEvent) 

**/ 

void menuConnectionDisConnect_actionPerformed(ActionEvent e) { 
disconnectO; 

} 

/** 

* Settings menu action performed 

* @param e (ActionEvent) 

**/ 

void menuSettings_actionPerformed(ActionEvent e) { 
if (currentDatabase != null){ 

Settings settings = new Settings(currentDatabase); 
settings.show(trae); 

} 

} 


/** 

* SQLExecute menu action performed 

* @param e (ActionEvent) 

**/ 

void menuSQLExecute_actionPerformed(ActionEvent e) { 
SQLExecuteO; 

} 


* New menu action performed 

* @param e (ActionEvent) 

**/ 

void menuDFQLNew_actionPerformed(ActionEvent e) { 
clearO; 

} 


124 



/** 

* Save menu action performed 

* @param e (ActionEvent) 

**! 

void menuDFQLSave_actionPerformed(ActionEvent e) { 
saveQ; 

) 


* Open menu action performed 

* @param e (ActionEvent) 

**/ 

void menuDFQLOpen_actionPerformed(ActionEvent e) { 
openO; 

} 


j** 

* DFQLExecute menu action performed 

* @param e (ActionEvent) 

void menuDFQLExecute_actionPerformed(ActionEvent e) { 
index = 0; 

DFQLExecuteO; 

} 


/* TOOL BUTTONS ACTION PERFORMED */ 

j** 

* Exit button action performed 

* @param e (ActionEvent) 

**/ 

void btnExit_actionPerformed(ActionEvent e) { 

System.exit(l); 

} 

!** 

* Print button action performed 

* @param e (ActionEvent) 

**/ 

void btnPrint_actionPerformed(ActionEvent e) { 
printO; 

} 


* Connect button action performed 

* @param e (ActionEvent) 

**/ 
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void btnConnect_actionPerformed(ActionEvent e) { 
connectO; 

} 


* Disconnect button action performed 

* @param e (ActionEvent) 

void btnDisConnect_actionPerfonned(ActionEvent e) { 
disconnectQ; 

} 


* SQLExecute button action performed 

* @param e (ActionEvent) 

void btnSQL£xecute_actionPerformed(ActionEvent e) { 
SQLExecuteO; 

} 

/** 

* New button action performed 

* @param e (ActionEvent) 

void btnNew_actionPerformed(ActionEvent e) { 
clear(); 

} 


* Save button action performed 

* @param e (ActionEvent) 

**/ 

void btnSave_actionPerformed(ActionEvent e) { 
save(); 

} 


j** 

* Open button action performed 

* @param e (ActionEvent) 

void btnOpen_actionPerformed(ActionEvent e) { 
openO; 

} 
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* DfqlExecute button action performed 

* @param e (ActionEvent) 

**! 

void btnDFQLExecute_actionPerformed(ActionEvent e) { 
index = 0; 

DFQLExecuteO; 

} 


* Manual button action performed 

* @param e (ActionEvent) 

**! 

void btnManual_actionPerformed(ActionEvent e) { 
help = new Help (); 

} 


* Send all button action performed 

* @param e (ActionEvent) 

void btnSendAll_actionPerformed(ActionEvent e) { 
index=0; 

indexDatabase = 0; 
sendToAllDatabasesO; 

} 

/* OPERATOR BUTTONS ACTION PERFORMED */ 

/** 

* Select button action performed 

* @param e (ActionEvent) '' 

**! 

void btnSelect_actionPerformed(ActionEvent e) { 

OperatorSelect select = new OperatorSelect(20*Counter[0],70); 

} 


* Project button action performed 

* @param e (ActionEvent) 

**/ 

void btnProject_actionPerformed(ActionEvent e) { 

OperatorProject project = new OperatorProject(20*Counter[l],70); 

} 
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/** 

* Join button action performed 

* @param e (ActionEvent) 

void btnJoin_actionPerformed(ActionEvent e) { 

Operator Join join = new OperatorJoin(20*Counter[2],70); 

} 


* Union button action performed 

* @param e (ActionEvent) 

void btnUnion_actionPerformed(ActionEvent e) { 

OperatorUnion union = new OperatorUnion(20*Counter[3],70); 

} 


* Different button action performed 

* @param e (ActionEvent) 

**/ 

void btnDiff_actionPerformed(ActionEvent e) { 
OperatorDiff diff = new OperatorDiff(20*Counter[4],70); 

} 


* Group count button action performed 

* @param e (ActionEvent) 

**/ 

void btnGroupCnt_actionPerformed(ActionEvent e) { 

OperatorGroupCnt gCount = new OperatorGroupCnt(20*Counter[5],70); 

} 


/** 

* Eqjoin button action performed 

* @param e (ActionEvent) 

**f 

void btnEqjoin_actionPerformed(ActionEvent e) { 

OperatorEqjoin select = new OperatorEqjoin(20*Counter[6],70); 

} 


/** 

* Group all satisfy button action performed 

* @param e (ActionEvent) 

void btnGrpAllSat_actionPerformed(ActionEvent e) { 

OperatorGrpAllSat grpAllSat = new OperatorGrpAllSat(20*Counter[7],70); 
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} 


!** 

* Group number satisfy button action performed 

* @param e (ActionEvent) 

void btnGrpNSat_actionPerformed(ActionEvent e) { 

OperatorGrpNSat grpNSat = new OperatorGrpNSat(20*Counter[8],70); 

} 

!** 

* Group maximum button action performed 

* @param e (ActionEvent) 

**/ 

void btnGrpMax_actionPerformed(ActionEvent e) { 

OperatorGrpMax grpMax = new C)peratorGrpMax(20*Counter[9],70); 

} 


/** 

* Group minimum button action performed 

* @param e (ActionEvent) 

**/ 

void btnGrpMin_actionPerformed(ActionEvent e) { 

OperatorGrpMin gipMin = new OperatorGrpMin(20*Counter[10],70); 

} 


/** 

* Group average button action performed 

* @param e (ActionEvent) 

**! 

void btnGrpAvg_actionPerformed(ActionEvent e) { 

OperatorGrpAvg grpAvg = new OperatorGrpAvg(20*Counter[l 1],70); 

} 


* Intersect button action performed 

* @param e (ActionEvent) 

void btnIntersect_actionPerformed(ActionEvent e) { 

Operatorintersect intersect = new OperatorIntersect(20*Counter[12],70); 

} 


I** 

* New user defined Operator button action performed 

* @param e (ActionEvent) 
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void userNew_actionPerformed(ActionEvent e) { 


designRelation 

designCondition 

designAttribute 

designOps 

designQueries 


= new VectorO; 
= new VectorO; 
= new VectorO; 
= new VectorO; 
= new VectorO; 


UserOperator userOperator = new UserOperatorO; 
setDesign (true); 

} 


* Load user defined Operator button action performed 

* @param e (ActionEvent) 

void userLoad_actionPerformed(ActionEvent e) { 
OpenFile loadUSO = new OpenFile(true); 

} 


* SQLExecute, sends the SQL query to the database currently active, 

* to be executed. 

**! 

void SQLExecuteO{ 
if (currentDatabase != null) 

{ 

sqlQuery = txtSQL.getXextO; 
try 

{ 

Table deneme = currentDatabase.executeQuery(sqlQuery); 
relation.assignData(deneme.getDataO, deneme.getAttributesO); 

} 

catch (SQLException ex) 

{ 

message.setMessage(ex.getMessageO); 

message.show(true); 

txtS QL.grabFocusO; 

} 

} 

} 


* DFQLExecute, sends the DFQL query to the database currently active, 

* to be executed. DFQL query consists of one or more operators. Each operator 

* produces a query of its own. According to the user choice, the result of an 

* operator can be displayed. This method, displays all the operators query 
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* results, which are selected to be displayed, one by one. 

**! 

void DFQLExecute(){ 
if (currentDatabase != null){ 
for(int xi = index ; xi < DFQLQuery.size();xi++){ 
tempOperator = (Operator)DFQLQuery.elementAt(xi); 
if (tempOperator.display){ 

btnNextl.setTextC’Displaying " + tempOperator .name); 
sqlQuery = tempOperator.query; 
if(xi !=DFQLQuery.size()-1) { 
btnNextl .setEnabled(true); 

} 

index = xi; 

DFQLDisplayO; 

break; 

} 

} 

} 

} 


* DFQLDisplay, displays the results of the operator queries. 

**! 

public void DFQLDisplayO { 
try{ 

Table deneme = currentDatabase.executeQuery(sqlQuery); 

txtSQL.setText(sqlQuery); 

relation.assignData(deneme.getDataO, 

deneme.getAttributesO); 

} 

catch (SQLException ex){ 
message.setMessage(ex.getMessage()); 
message.show(true); 
txtSQL.grabFocusO; 

} 


* Next 1 button is used to switch from one operators result to the following 
**! 

void btnNextl_actionPerformed(ActionEvent e){ 
index++; 

btnNextl .setEnabled(false); 

DFQLExecuteO; 

} 
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* Next 2 button is used to switch from one database to the following one 

void btnNext2_actionPerformed(ActionEvent e){ 
index = 0; 
indexDatabase-H-; 
btnNext2.setEnabled(false); 
sendToAllDatabasesO; 

} 


* Clear, removes all elements of the vectors, initiates all the variables, 

* clears all the panel, tables and etc. 

**f 

public void clear() { 
cnvDFQL.clearQ; 
for (int xi = 0; xi<13;xi++){ 

Counter[xi] = 1; 

} 

DFQLQuery .remove AllElementsO; 
txtSQL.setText(""); 

btnNextl .setText("DISPLAY OPERATOR"); 
btnNext2.setText("DISPLAY DATABASE"); 

} 

/** 

* Creates a print frame to print the result 
public void print(){ 

PrintPreview print = new PrintPreview(SQLResult); 
print.print(); 

} 


* Creates a open file frame to load a previously saved dfql query 

**/ 

public void open(){ 
if (currentDatabase != null){ 

OpenFile open = new OpenFileQ; 

} 

} 

* Creates a save file frame to save the current dfql query 
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public void save(){ 
saveConfig save = new saveConfigO; 

} 


* This method is used to generate a tree which shows database meta data 

* at every connection or disconnection this tree is updated. 

**l 

void generateTree () throws SQLException{ 

DefaultTreeModel result = null; 

int databaseCount = databaseList.size(); 

DefaultMutableTreeNode top = new DefaultMutableTreeNode 

("Database URLs"); 
DefaultMutableTreeNode parent = top; 

Database tempDB; 

for (int index = 0; index < databaseCount; index++){ 
tempDB = (Database) databaseList.elementAt(index); 
parent.add(tempDB.getTreeModel()); 

} 

result = new DefaultTreeModel(top); 
treeMeta. setModel(result); 

} 


/** 

* This method is used to send the prepared DFQL or SQL query to the 

* currently 

* connected databases. It starts from the first database connected and 

* switchs to the next one every time next! button is pressed. 

**! 

void sendToAlIDatabases(){ 

for (int ix = indexDatabase; ix<databaseList.size();ix-i-+){ 
currentDatabase = (Database)databaseList.elementAt(ix); 
this. setTitle(currentDatabase.getURL()); 
btnNext2.setText("Displaying" + currentDatabase.getURLO); 
if(ix<databaseList. size()-1) { 
btnNext2.setEnabled(true); 

} 

if (indexPanel == 0){ 

SQLExecuteO; 

break; 

} 

if (indexPanel == 1){ 
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index = 0; 

DFQLExecuteO; 

break; 

} 

} 


// DBSelectionListener inner class 

* This inner class is used to add a listener to the database tree. This listener 

* allows user to select a database or table of a database or attribute of a table. 

* according to the selection, the information presented about the database 

* changes. 

class DBSelectionListener implements TreeSelectionListener{ 

public void valueChanged(TreeSelectionEvent e){ 

TreePath path = e.getNewLeadSelectionPath(); 

TreePath oldPath = e.get01dLeadSelectionPath(); 
if (path != null){ 

DefaultMutableTreeNode tempNode; 

Object [] nodes = path.getPath(); 

DefaultMutableTreeNode node = (DefaultMutableTreeNode) 

nodes[nodes.length-1 ]; 

String selectedName = (String) node.getUserObject(); 
panelMain.setSelectedIndex(2); // Activate the Definition pane 

if (currentDatabase != null) { 
if (nodes.length > 1) { 

DefaultMutableTreeNode nodeDB = (DefaultMutableTreeNode) 

nodes[l]; 

String selectedDB = (String) nodeDB.getUserObject(); 
for (int index = 0; index<databaseList.size();index-i-+){ 

Database temp = (Database) databaseList.elementAt(index); 
if (selectedDB.equalsIgnoreCase(temp.getURL())) { 
if (!(selectedDB.equalsIgnoreCase(currentDatabase.getURL()))) { 
currentDatabase = temp; 
treeMeta.collapsePath(oldPath); 
break; 

} 

} 

) 

} 


try { 

switch (nodes.length) { 
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case 2 : 

metaData.setText(" URL : " + currentDatabase.getURL()+ "\n"); 
metaData.append (" DRIVER:" + currentDatabase.getDriver () + "\n"); 
metaData.append (" USERID"+currentDatabase.getUserName()+ "\n"); 
metaData.append(" PROGRAM NAME : " + 

currentDatabase.getDatabasePrograniName()+"\n"); 
metaData.append (" FULL ANSI92 : " + 

cuiTentDatabase.isSupportANSI92()+ "\n"); 
test.window.setTitle(currentDatabase.getURL()); 
break; 
case 3 : 

tempNode = (DefaultMutableTreeNode) nodes[2]; 

Vector atts = currentDatabase.getTable Attributes 
((String)tempNode.getUserObject()); 

Vector tableData = currentDatabase.getTableData 

((String)tempNode.getUserObject()); 
panelMain.setSelectedIndex(3); 
relationTable.assignData(tableData, atts); 
break; 
c£ise 4 : 

Vector attrs; 

Attribute tempAttr; 

tempNode = (DefaultMutableTreeNode) nodes [2]; 
attrs = currentDatabase.getTableAttributes 

((String)tempNode.getUserObject()); 
for (int attindex = 0; attindex < attrs.size(); attIndex-H-) { 
tempAttr = (Attribute)attrs.elementAt(attlndex); 
if (selectedName.equalsIgnoreCase(tempAttr.getAttributeName())) { 
metaData.setText(" TYPE + tempAttr.getAttributeType()+"\n"); 
metaData.append (" SIZE: " + tempAttr.getAttributeSize()+ "\n"); 
metaData. append (" NULLABLE+ tempAttr.isNullable()+"\n"); 
metaData.append (" SEARCHABLE :" + 

tempAttr.isSearchable()+"\n"); 
metaData.append (" CASE SENS.: " + 

tempAttr.isCaseSensitive()+"\n"); 

break; 

} 

} 

break; 

default: break; 

} 

} 

catch (SQLException exs) { 

message.setMessage(exs.getMessage()); 

message.show(true); 
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} 

} 

} 

} 

} 

void txtSQL_coinponentShown(ComponentEvent e) { 
arrangeDisplayO 5 

} 

void metaData_componentShown(ComponentEvent e) { 
arrangeDisplayO; 

} 

void panelTableData_componentShown(ComponentEvent e) { 
arrangeDisplayO; 

} 

void denememe_componentShown(ComponentEvent e) { 
arrangeDisplayO; 

} 

* In order to switch between the panels. If DFQL panel is selected, then 

* Operators Panel becomes visible. 

void arrangeDisplay () { 
int selindex = panelMain.getSelectedIndexO; 
if (selhidex == 1){ 
panelOperators.setVisible(true); 

} 

else { 

panelOperators.setVisible(false); 

} 

indexPanel = selindex; 

} 

/** 

Changes the mode of the program 
**! 

void setDesign (boolean newDesign){ 
design = newDesign; 

} 
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/** 

Returns the mode of the program 

boolean isDesign (){ 
return design; 

} 


String getProgramPath(){ 
return path; 

} 


} 


10- Message-Java 

package ThesisGUI; 
import java.awt.*; 
import j avax. swing. *; 
import java.awt.event.*; 

!** 

* This frame is used to display error, warning, exception and information 

* messages, such as "no connection established" 

* AUTHOR: IS & BA 

**/ 

public class Message extends JFrame { 

/** Scroll panel for message text area **/ 

JScrollPane panelError = new JScrollPane(); 

/** Text area to display the messages **/ 

JTextArea txtError = new JTextAreaQ; 

/** close button to close this frame**/ 

JButton bmClose = new JButton(); 


CONSTRUCTOR 


/* 

/** 

* The constractor 

**f 

public MessageO { 
try { 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 


*/ 
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INITIATE METHOD 


/* 

/** 

* The initiation 


*/ 


* creates the frame, close button, text area and scroll pane. Initiates them. 
**/ 


private void jblnitQ throws Exception { 

this.setTitle ("Message"); 
btnClose. setT ext(" Close"); 

panelError.setBounds(newRectangle(10,10, 300, 50)); 
btnClose.setBounds (new Rectangle(120,65,70,25)); 
txtError.setEditable(false); 

btnClose.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnClose_actionPerformed(e); 

}}); 

this.getContentPane().setLayout (null); 
this.getContentPane().add (panelError, null); 

this.getContentPane(Tadd (btnClose, null); 

panelError.getViewport().add (txtError, null); 
setBounds(350,200,330,120); 

} 

/** Changes the contents of the text area with new message 

* @param message (String) 

void setMessage(String message)! 
txtError. setText(message); } 

/** Terminates this frame 

* @param message e (ActionEvent) 

void btnClose_actionPerformed( ActionEvent e){ 
this.disposeO; 

} 

} 

11. OpenFile.Java 

package ThesisGUI; 
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import java.awt.*; 
import javax.swing.*; 
import java.awt.event. *; 
import java.io.*; 

* This frame is designed to be used to open previously designed queries. 

* In other words, It is basically for the user defined operators. 

* AUTHOR: IS & BA 

public class OpenFile extends JFrame { 

/** File Dialog object for loading a file **/ 

FileDialog file = new FileDialog(this,"Lx)ad File",FileDialog.LOAD); 

I** 

* Boolean TRUE : if user wants to load a user defined operator 

* FALSE : if user wants to load a pre-executed and saved DFQL query 

**/ 

boolean isUSO = false; 

/* CONSTRUCTORS */ 

f** 

* The default constructor 

**/ 

public OpenFileO { 
try { 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 

/** 

* The constructor to create an instance for loading a user defined operator 

* @param yes boolean 

public OpenFile(boolean yes) { 
try { 

isUSO = yes; 

JblnitO; 

} 

catchQException e) { 
e.printStackTraceO; 

} 

} 
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/* INITIATE METHOD */ 

* The initiation 

* creates the file dialog object. And inititates it. 

* Later on calls load config method. 

**! 

private void jblnit() throws Exception { 
this.setResizable (false); 

if(isUSO){ 

file.setDirectory (test.window.getPrograinPath()+"\\operator\\"); 

file.setFile ("*.uso"); 
loadUSOQ; 

} 

else{ 

file.setDirectory (test.window.getProgramPath()+"\\dfql\\"); 

file.setFile ("*.dfql"); 
loadConfigO; 

} } 


* This method is used to configure the OpenFile object to load a DFQL query. 

* Checks the name of the file. If a file is selected. It calls the transfer 

* method, otherwise just cancel the job. 

void loadConfigO { 
file.show(true); 

String fileName = file.getFile(); 
if (fileName != null){ 
fileName = file.getDirectoryO + fileName; 
transfer(fileName); 

} 

} 


* Creates the ".dfql" file objects, which are going to be used during file 

* loading, the first line of the file specifies the length of the file. 

* According to this number it reads every line, creates a new operator 

* object with this information and calls add method of the draw class. 

* @param fileName (String) 

void transfer (String fileName) { 
try{ 

File newFile = new File (fileName); 

FileReader inStream = new FileReader (newFile); 
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BufferedReader bufFile = new BufferedReader (inStream); 
String line = bufFile.readLine(); 

int number = Integer.parselnt(line); 

Operator operatorl = new OperatorQ; 

for(int xi = 0; xi<number;xi-H-){ 
line = bufFile.readLineO; 
if (line.equalsIgnoreCaseC'select")){ 
test.window.Counter[0] = test.window.Counter[0] + 1; 

} 

else if (line.equalsIgnoreCaseC'project")){ 
test.window.Counter[l] = test.window.Counter[l] + 1; 

} 

else if (line.equalsIgnoreCase("diff')){ 
test.window.Counter[4] = test.window.Counter[4] + 1; 

} 

else if (line.equalsIgnoreCaseC'eqjoin")){ 
test.window.Counter[6] = test.window.Counter[6] + 1; 

} 

else if (line.equalsIgnoreCaseC'groupcnt")){ 
test.window.Counter[5] = test.window.Counter[5] + 1; 

} 

else if (line.equalsIgnoreCase("grpallsat")){ 
test.window.Counter[7] = test.window.Counter[7] + 1; 

} 

else if (line.equalsIgnoreCase("grpavg")){ 
test.window.Counter[ll] = test.window.Counter[ll] + 1; 

} 

else if (line.equalsIgnoreCaseC'grpmax")){ 
test.window.Counter[9] = test.window.Counter[9] + 1; 

} 

else if (line.equalsIgnoreCaseC’grpmin")){ 
test.window.Counter[10] = test.window.Counter[10] + 1; 

} 

else if (line.equalsIgnoreCaseC'grpnsat")){ 
test.window.Counter[8] = test.window.Counter[8] + 1; 

} 

else if (line.equalsIgnoreCaseC'intersect")){ 
test.window.Counter[12] = test.window.Counter[12] + 1; 

} 

else if (line.equalsIgnoreCaseC'join")){ 
test.window.Counter[2] = test.window.Counter[2] + 1; 

} 

else if (line.equalsIgnoreCaseC'union")){ 
test.window.Counter[3] = test.window.Counter[3] + 1; 

} 
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operator 1. setT ype(line); 
line = bufFile.readLineO; 

operatorl .setName(line); 
line = bufFile.readLineO; 

operatorl.setX(Integer.parseM(line)); 
line = bufFile.readLineO; 

operatorl.setY(Integer.parseInt(line)); 
line = bufFile.readLineO; 

operatorl.setNumberOfInputNodes(Ihteger.parseInt(line)); 
line = bufFile.readLineO; 

if (line.equals("true’')){ 
operatorl .setDisplay(true); 

} 

else{ 

operatorl .setDisplay(false); 

} 

line = bufFile.readLineO; 
operatorl .setQueiy(line); 

String [] input = {"none","none","none","none"}; 

forfint di=0;di<(operatorl .nuniberOfInputNodes);di-H-){ 
line = bufFile.readLineO; 
input[di] = line; 

} 

test.window.cnvDFQL.add(operator 1 .x,operatorl .y, 

operatorl .name, operatorl .numberOfInputNodes, 
input, operatorl .display, operatorl.type, 
operatorl.query); 

} 

bufFile.closeO; 

} 

catch (lOException e){ 

test.window.message.setMessage(e.getMessageO); 

test.window.message.show(true); 

} 

} 
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!** 

* This method is used to configure the OpenFile object to load a user 

* defined operator. Checks the name of the file. If a file is selected, 

* it reads the file and creates an instance of the OperatorUser class 

* using the data stored in the file 
**! 

void loadUSO(){ 
int X, y, rel, con, att; 

String query, type; 
file.show(true); 

String fileName = file.getFile(); 

if (fileName != null){ 

fileName = file.getDirectoryO + fileName; 


try{ 


File newFile = new File (fileName); 

FileReader inStream = new FileReader (newFile); 
BufferedReader bufFile = new BufferedReader (inStream); 


String line 

X 

line 

y 

line 

rel 

line 

con 

line 

att 

line 

query 

line 

type 


= bufFile.readLineO; 

= Integer.parselnt(line); 
= bufFile.readLineO; 

= Integer.parsehit(line); 
= bufFile.readLineO; 

= Integer.parselnt(line); 
= bufFile.readLineO; 

= Integer.parsehit(line); 
= bufFile.readLineO; 

= hiteger.parselnt(line); 
= bufFile.readLineO; 

= line; 

= bufFile.readLineO; 

= line; 


OperatorUser loaded = new OperatorUser(x,y,rel,con,att,query,type); 


bufFile.closeO; 

} 

catch (lOException e){ 

test.window.message.setMessage(e.getMessage()); 

test.window.message.show(true); 

}} 

} 

} 
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12. Operator.Java 


package ThesisGUI; 


* This is one of the main class of our design. It holds all the information, 

* we need to know about the operator. 

* AUTHOR : IS & BA 

public class Operator { 

/** X coordinate of the operator **/ 
protected int x; 

/** Y coordinate of the operator **! 
protected int y; 

/** The number of the input nodes of the operator **/ 
protected int numberOfInputNodes; 


/** name of the operator **! 
protected String name; 

/** Contents of the input nodes of the operator **/ 
protected String [] input = new String[4]; 

/** Display info for the operator **/ 
protected boolean display; 

/** Type of the operator **/ 
protected String t)^; 

/** SQL query that this operator represents **/ 
protected String query; 

/* CONSTRUCTOR */ 

/** 

* Default constructor 
public Operator(){} 

/* CONSTRUCTOR */ 

* Constructor with initial parameters 

* @ parameters x, y, and number (integer). 
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* name, []input, type and query (String), 

* display (boolean) 

public Operator(int x, int y. String name, int number. String [] input, 
boolean display, String type, String query) { 


this.x 

= x; 

this.y 

= y; 

this.name 

= name; 

this.numberOfInputNodes 

= number; 

this.display 

= display; 

this.type 

= type; 

thi&.queiy 

= query; 

this.input[0] 

= input[0]; 

this.input[l] 

= input[l]; 

this.input[2] 

= input[2]; 

this.input[3] 

= input[3]; 


/* Set Methods */ 

/** 

* Sets the value of the X coordinate 

* ©parameter X (integer) 

public void setX(int x){ 
this.x = x; 

} 


/** 

* Sets the value of the Y coordinate 

* ©parameter Y (integer) 

**/ 

public void setY(int y){ 
this.y = y; 

} 


* Sets the operator name 

* ©parameter name (String) 

**! 

public void setName(String name){ 
this.name = name; 

} 


!** 

* Sets the number of the input nodes of the operator 

* ©parameter number (integer) 
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public void setNumberOfInputNodes(int number) { 
this.numberOfInputNodes = number; 

} 


* Sets the value of the display 

* ©parameter display (boolean) 

**/ 

public void setDisplay(boolean display) { 
this.display = display; 

} 

* Sets the type of the operator 

* ©parameter type (String) 

public void setType(String type){ 
this, type = type; 

} 


* Sets the input values of the operator 

* ©parameter input ([]String) 

public void setinput (String [] input) { 
for(int xi =0; xi<numberOfInputNodes;xi++){ 
this.input[xi] = input[xi]; 

} 

} 


* Sets the sql query of the operator 

* ©parameter query (String) 

public void setQuery (String query) { 
this.query = query; 

} 


* Gets the value of the input nodes of the operator 

* ©parameter input ([]String) 

**! 

public String [] getitaput (){ 
return input; 

}} 
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13. OperatorDiffJava 


package ThesisGUI; 

import j ava. awt. event. *; 
import java.io.*; 
import java.util.*; 
import java.awt.*; 
import javax.swing.*; 
import java.util.Vector; 
import javax.accessibility.*; 
import javax.swing.UIManager; 

!** 

* This frame is used to allow the user to enter the operator informatipn 

* for different operator. It also allwos user to change the information 

* previously entered. 

* AUTHOR: IS & BA 

**! 

public class OperatorDiff extends JFrame implements WindowListener{ 
/** Type of the operator (constant) **/ 
final static String OPERATOR.TYPE = "Diff 

/** Input node number of the operator (constant) **/ 
final static int NO_lNPUT_NODES = 3; 

/** X coordinate of the operator**/ 
private int x; 

/** Y coordinate of the operator**/ 
private int y; 

/** name of the operator**/ 
private String name; 

/** first input node relation**/ 
private String relation 1; 

/** second input node relation**/ 
private String relation2; 

/** name of the common attribute**/ 
private String attribute; 

/** display information for the operator**/ 
private boolean display = false; 
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/** SQL query of the operator**/ 
private String query; 

/** Specify why this frame is called (to create a new one (false) 

* or change the current operator (true)**/ 
private boolean whoIsCalling = false; 

/** The index of the operator in the Operators list **/ 
private int indexNum; 

/** The index of the operator in the DFQLList**/ 
private int current; 

/** name label of the frame**/ 

JLabel IblName = new JLabel(); 

/** first relation label of the frame**/ 

JLabel IblRelationl = new JLabel(); 

/** second relation label of the frame**/ 

JLabel lblRelation2 = new JLabel(); 

/** common attribute label of the frame**/ 

JLabel Ibl Attribute = new JLabel(); 

/** text area to enter the name of the operator default diff#**/ 
JTextField txtName = new JTextField(); 

/** text area to enter the name of the coomon attribute**/ 

JTextField txtAttiibute = new JTextField(); 

/** Okay button to confirm the info entered**/ 

JButton btnOK = new JButton(); 

/** check box for display information**/ 

JCheckBox chkResult = new JCheckBox(); 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelationl = new JComboBox(); 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelation2 = new JComboBox(); 


148 



/** Combo box lists the available attributes that can be 

* related to this operator**/ 

JComboBox cmbAttribute = new JComboBoxQ; 

/** Button cancel to cancel this operation**/ 

JButton btnCancel = new JButton(); 

/* CONSTRUCTOR */ 

* Default constructor 

* ©parameters X and Y (integer) coordinates of the operator 
**/ 

public OperatorDiff(int x, int y) { 
try { 

this.x = x; 
this.y = y; 
jblnitQ; 

} 

catch(Exception e) { 
e.printStackTrace(); 

} 

} 


* Constructor with all parameters 

* ©parameters © parameters x, y, callerl, caller2 (integer), 

* name,relation 1, relation2 (String), 

* display (boolean) 

public OperatorDiff(int x, int y, int callerl, int caller2. String name, 

^ String relation 1, String relation2. String attribute, boolean display) 

this.x = x; 

this.y z= y; 

this.cuirent = caller 1; 

this.indexNum = caller2; 

this.whoIsCalling = true; 

this.name = name; 

this.relation 1 = relation 1; 

this.relation2 = relation2; 

this.attribute = attribute; 

this.display = display; 

txtName.setText(name); 
if (display)! 

chkResult.setSelected(true); 



} 

else{ 

chkResult.setSelected(false); 

} 

try { 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 

!** 

* Design constructor 

* ©parameters name 

public OperatorDiff(String name) { 
try { 

this.name = name; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 


/* INITIATE METHOD */ 

!** 

* The initiation 

* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 

private void jblnitO throws Exception { 


IblName.setText 
this.setTitle 
IblRelation 1 .setText 
lblRelation2.setText 
IblAttribute.setText 
chkResult.setText 
bmOK.setText 
btnCancel. setText 


("Name"); 
("Diff’); 
("Relationl"); 
("Relation2"); 
("Attribute"); 
("Display"); 
("OK"); 
("Cancel"); 


IblName.setBounds 
IblRelation 1. setBounds 
lblRelation2.setBounds 
IblAttribute.setBounds 


(new Rectangle(4,2,93,18)); 
(new Rectangle(4, 27,93, 18)); 
(new Rectangle(4,50,93,18)); 
(new Rectangle(4,73,93,18)); 
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txtName.setBounds (new Rectangle(80,2,114,17)); 

txtAttribute.setBounds (new Rectangle(80,73, 114,17)); 
btnOK.setBounds (new Rectangle(142,100,54,22)); 

chkResult.setBounds (new Rectangle(4, 100, 61,22)); 
cmbRelationl.setBounds (new Rectangle(80,28,114,17)); 
cmbRelation2.setBounds (new Rectangle(80,51, 114, 17)); 
cmbAttribute.setBounds (new Rectangle(80,73, 114,17)); 
btnCancel.setBounds (new Rectangle(74,100, 60,23)); 

if (test.window.isDesign()){ 
loadDesignO; 

} 

else { 

loadSelectO; 

} 

btnOK.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnOK_actionPerformed(e); 

}}); 

btnCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerfomied(ActionEvent e) { 
btnCancel_actionPerformed(e); 

}}); 

chkResult.setBorderPainted(true); 
cmbRelationl.setBorder (null); 
cmbRelation2.setBorder (null); 

chkResult.setFont (new java.awt.Font("Dialog", 0,11)); 
btnCancel.setFont (new java.awt.Font("DiaIog", 0,11)); 
btnOK-setFont (new java.awt.Font("Dialog", 0,11)); 

btnOK-setBorder (BorderFactory.createRaisedBevelBorderO); 
chkResult.setBorder (BorderFactory.createRaisedBevelBorderO); 
btnCancel.setBorder (BorderFactory.createRaisedBevelBorderO); 

this.getContentPane().setLayout(null); 
this.getContentPane().add(lblName, null); 
this.getContentPane().add(txtNanie, null); 
this.getContentPane().add(lblRelationl, null); 
this.getContentPane().add(cmbRelation 1, null); 
this.getContentPane().add(cmbRelation2, null); 
this.getContentPane().add(lblRelation2, null); 
this.getContentPane().add(chkResult, null); 


151 



this.getContentPane().add(btnCancel, null); 
this.getContentPane0.add(btnOK, null); 
this.getContentPane().add(lblAttribute,null); 
if (test.window.isDesign()){ 
this.getContentPane().add(cmbAttribute, null); 

} 

else { 

this.getContentPane().add(txtAttribute, null); 

} 

this.setBounds(100,100,210,170); 
this.show(true); 

} 

/* Set Methods */ 

I** 

* Sets the first relation of the operator 

* ©parameter relation! (String) 

public void setRelationl (String relation 1){ 
this.relation 1 = relation 1; 

} 


* Sets the second relation of the operator 

* ©parameter relation2 (String) 

public void setRelation2 (String relation2){ 
this.relation2 = relation2; 

} 


* Sets the common attribute of the operator 

* ©parameter attribute (String) 

**! 

public void setAttribute (String attribute) { 
this.attribute = attribute; 

} 


* Sets the name of the operator 

* ©parameter name (String) 

public void setName (String name){ 
this.name = name; } 

/* . Get Methods */ 
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* Gets the number of the input nodes of the operator 
**! 

public int getnumberOfNodes(){ 
return this.NO_INPUT_NODES; 

} 


* Gets the type of the operator 
**/ 

public String getOperatorType(){ 
return this.OPERATOR_TYPE; 

} 


* Gets the first relationof the operator 

public String getRelationl (){ 
return this.relationl; 

} 


f** 

* Gets the second relation of the operator 
**/ 

public String getRelationl (){ 
return this.relationl; 

} 


* Gets the name of the common attribute 

**l 

public String getAttribute (){ 
return this.attribute; 

} 


* Gets the name of the operator 
**/ 

public String getName (){ 
return this.name; } 

/* WINDOW ACTIVATIONS */ 

/** 

* The window listener methods 

* @param event (WindowEvent) 
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public void windowClosing 
public void window Activated 
public voi4 windowClosed 
public void windowDeactivated 
public void windowDeiconified 
public void windowiconified 
public void windowOpened 


(WindowEvent event) { Systeni.exit(O);} 
(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 


* button okay action performed 

* Takes the information entered for the operator. Creates a new operator and 

* calls add or change method of the draw class. And sends new operator 

* information there to be added to the list. 

* @param e (ActionEvent) 

void btnOK_actionPerformed(ActionEvent e) { 
if(chkResult.isSelected()) { 
display = true; 

} 

else{ 

display = false; 

} 


setName (txtName.getText()); 
setRelation 1 ((String)cmbRelation 1 .getSelectedItem()); 
setRelation2 ((String)cmbRelation2.getSelectedItem()); 
if (test.window.isDesign()){ 
setAttribute((String)cmbAttribute.getSelectedItem()); 

} 

else{ 

setAttribute(txtAttribute.getText()); 

if(txtAttribute.getText().equals("")){ 

test.window.message.setMessageC'You did not enter the attribute list"); 
test.window.message.show(true); 

} 

} 

String [] input = {getRelationl(),getRelation2(),getAttribute(),"none","none"}; 
buildQueiyO; 

if (test.window.isDesign()){ 
test.window.designQueries.addElement(query); 

else { 

if (whoIsCalling){ 
test.window.cnvDFQL.change 
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(current,indexNum,x,y,getName(),getoumberOfNodes(), 
input,display, getOperatorType(), query); 

} 

else{ 

test.window.cnvDFQL.add 

(x,y,getName(),getnumberOfNodes(),input,display, 
getOperatorTypeQ, query); 

} 

} 

this.disposeO; 

} 

/** 

* Loads the relations with the tables of the selected database and previously 

* created operators. 

void loadSelectO { 
if(! whoIsCalling) { 

txtName.setText("Diff'+test.window.Counter[4]-H-); 

} 

Vector deneme = test.window.currentDatabase.getTableNamesQ; 
for (int index = 0 ; index < deneme. sizeQ; index-H-) { 
cmbRelationl .addItem((String) deneme.elementAt(index)); 
cmbRelation2.addItem((String) deneme.elementAt(index)); 

} 

for (int xi = 0; xi <test.window.cnvDFQL.numC)fOperators;xi-H-){ 
cmbRelationl.addltem(test. window .cnvDFQL.operators[xi].name); 
cmbRelation2.addItem(test. window .cnvDFQL.operators[xi].name); 

} 

cmbRelation 1 .removeItem(name); 
cmbRelation2.removeItem(name); 

if (relation 1= null) 
cmbRelation 1. sets electedLidex(0); 
else 

cmbRelationl .setSelectedItem(relation 1); 

if (relation2== null) 
cmbRelation2.setSelectedIndex(0); 
else 

cmbRelation2.setSelectedItem(relation2); 
txtAttribute.setText(attribute);} 
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* button cancel action performed 

* terminates this frame without creating an operator, decrements the counter 

* @param e (ActionEvent) 

void btnCancel_actionPerformed(ActionEvent e) { 
test.window.Counter[4]-; 
this.disposeO; 

} 


* This portion of the code produces the SQL query for this operator according 

* to the information entered by user. 

public void buildQuery(){ 

String checkRelation = isOtherOperator (relation 1); 
if (checkRelation == null) { 

query = "select distinct" + attribute +" from " + relation 1 + 

" S where S." + attribute + " not in"; 

} 

else { 

query = "select distinct" + attribute + " from " + "(" + 

checkRelation +") S where S." + attribute +" not in"; 

} 

checkRelation = isOtherOperator(relation2); 
if (checkRelation = null) { 

query = query + " (select " + attribute + " from " + relation2 + ")"; 

} 

else ( 

query = query + "(select" + attribute + " from" +"(" +checkRelation +"))"; 

} 


* This portion of the code looks for the type of the relations, if they are 

* tables it returns null, otherwise if is another operator, it returns the 

* query of the operator which the current operator related to. 

public String isOtherOperator (String type) { 

String result = null; 

for (int index = 0; index < test.window.DFQLQuery.size(); index++) { 
Operator temp = (Operator) test.window.DFQLQueiy.elementAt(index); 
if (type.equalsIgnoreCase(temp.name)) { 
result = temp.query; 
break; 
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} 

} 

return result; 

} 


* This function is used to fill the combo boxes with the selection alternatives 

* if this operator is created as a part of a user defined operator then the 

* relation and condition combo boxes are filled with user defined operator 

* input items. 


private void loadDesign(){ 
txtName.setText(name); 

for (int index = 0; index < test.window.designRelation.size(); index-H-) { 
cmbRelationl .addItem((String) test.window.designRelation.elementAt 

(index)); 

cmbRelation2.addItem((String) test.window.designRelation.elementAt 

(index)); 


} 


for (int opindex = 0; opindex < test.window.designOps.size(); opIndex-H-) { 
if (!name.equalsIgnoreCase((String) test.window.designOps.elementAt 

(opindex))) { 

cmbRelationl .addItem((String) test.window.designOps.elementAt 

(opindex)); 

cmbRelation2.addItem((String) test.window.designOps.elementAt 

(opindex)); 

} 

} 


for (int attindex = 0; atthidex < test.window.designAttribute.size(); 
attIndex-H-){ 

cmb Attribute. addItem((Stting) test.window.designAttribute.elementAt 
(attindex)); 

} 

} 

} 


14. Operator£<ijoin.Java 


package ThesisGUI; 

import java.awt.event.*; 
import java.io.*; 
import java.util.*; 
import java.awt.*; 
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import javax.swing.*; 
import java.util. Vector; 
import javax.accessibility.*; 
import javax.swing.UIManager; 

* This frame is used to allow the user to enter the operator information 

* for Eqjoin operator. It also allwos user to change the information 

* previously entered. 

* AUTHOR: IS & BA 

public class OperatorEqjoin extends JFrame implements WindowListener{ 
/** Type of the operator (constant) **/ 
final static String OPERATOR_TYPE = "Eqjoin"; 

/** Input node number of the operator (constant) **/ 
final static int NO_INPUT_NODES = 3; 

/** X coordinate of the operator**/ 
private int x; 

/** Y coordinate of the operator**/ 
private int y; 

/** name of the operator**/ 
private String name; 

/** first input node relation**/ 
private String relation 1; 

/** second input node relation**/ 
private String relation2; 

/** Join attribute list**/ 
private String JoinAtList; 

/** display information for the operator**/ 
private boolean display = false; 

/** SQL query of the operator**/ 
private String query; 

/** Specify why this frame is called (to create a new one (false) 

* or change the current operator (true)**/ 
private boolean whoIsCalling = false; 
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/** The index of the operator in the Operators list **/ 
private int indexNum; 

/** The index of the operator in the DFQLList**/ 
private int current; 

/** name label of the frame**/ 

JLabel IblName = new JLabelQ; 

/** first relation label of the frame**/ 

JLabel IblRelationl = new JLabel(); 

/** second relation label of the frame**/ 

JLabel lblRelation2 = new JLabel(); 

/** text area to enter the name of the operator default diff#**/ 
JTextField txtName = new JTextField(); 

/** Okay button to confirm the info entered**/ 

JButton btnOK = new JButton(); 

/** check box for display information**/ 

JCheckBox chkResult = new JCheckBox(); 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelationl = new JComboBox(); 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelation2 = new JComboBox(); 

/** join attribute list label of the firame**/ 

JLabel IblJoinAtList = new JLabel(); 

/** text area to enter the join attribute list for the operator**/ 
JTextField txtJoinAtList = new JTextField(); 

/** Combo box lists the available conditions that can be 

* related to this operator**/ 

JComboBox cmbAttribute = new JComboBox(); 

/** Button cancel to cancel this operation**/ 

JButton btnCancel = new JButton(); 
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/* CONSTRUCTOR */ 

/** 

* Default constructor 

* ©parameters X and Y (integer) coordinates of the operator 
**/ 

public OperatorEqjoin(int x, int y) { 
try { 

this.x = x; 
this.y = y; 
jblnitO; 

) 

catch(Exception e) { 
e.printStackTraceO; 

) 

} 




* Constructor with all parameters 

* ©parameters © parameters x, y, callerl, caller2 (integer), 

* name,relationl, relation2, joinAtList (String), 

* display (boolean) 


public OperatorEqjoin(int x, int y, int callerl, int caller2, String name. 
String relation 1, String relation2. String joinAtList, 
boolean display)! 


this.x 

this.y 

this.current 
this.indexNum 
this.whoIsCalling 
this.name 
. this.relation 1 
this.relation2 
this.JoinAtList 
this.display 


= x; 

= y; 

= callerl; 

= caller2; 

= tme; 

= name; 

= relation 1; 
= relation2; 
=JoinAtList; 
= display; 


txtName.setText (name); 
txtJoinAtList.setText (JoinAtList); 


if (display)! 

chkResult.setSelected(true); 

} 

else! 

chkResult.setSelected(false); 

} 
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tiy { 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 


/** 

* Design constructor 

* ©parameters name 

public OperatorEqjoin(String name) { 

try { 

this.name = name; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 


/* INITIATE METHOD */ 

/** 

* The initiation 

* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 


private void jblnit() throws 
IblName.setText 
this.setTitle 
IblRelation 1 .setText 
lblRelation2.setText 
lblJoinAtList.setText 
btnOK.setText 
chkResult. setT ext 
btnCancel.setText 


Exception { 
("Name"); 
("Eqjoin"); 
("Relationl"); 
("Relation2"); 
("JoinAttList"); 
("OK"); 
("Display"); 
("Cancel"); 


IblName.setBounds 

IblRelation 1 .setBounds 

lblRelation2.setBounds 

IblJoinAtListsetBounds 

txtName.setBounds 

txtJoinAtList.setBounds 

cmbAttribute.setBounds 

btnOK.setBounds 


(new Rectangle(4,2, 93, 18)); 
(new Rectangle(4,27,93,18)); 
(new Rectangle(4,49, 93, 18)); 
(new Rectangle(4,72,93,18)); 
(new Rectangle(80,2,114,17)); 
(new Rectangle(80,73,114,17)); 
(new Rectangle(80,73,114,17)); 
(new Rectangle(142,95, 53,22)); 
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chkResult-setBounds (new Rectangle(2,95, 63,22)); 
cmbRelationl.setBounds (new Rectangle(80,28,114,17)); 
cmbRelation2.setBounds (new Rectangle(80, 50,114, 17)); 
btnCancel.setBounds (new Rectangle(70,95,68,22)); 

if (test.window.isDesign()){ 
loadDesignO; 

} 

else { 

loadSelectO; 

} 

btnOK.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnOK_actionPerformed(e); 

}}); 

btnCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerfonned(ActionEvent e) { 
btnCancel_actionPerformed(e); 

}}); 

this.getContentPane().setLayout (null); 
cmbRelation 1. setBorder (null); 

cmbRelation2.setBorder (null); 

chkResult.setBorderPainted (trae); 

btnOK.setFont (new java.awt.Font("Dialog", 0,11)); 
chkResult.setFont (newjavaawt.Font("Dialog", 0,11)); 
btnCancel.setFont (new java.awt.Font("Dialog", 0,11)); 

btnOK.setBorder (BorderFactory.createRaisedBevelBorder()); 
chkResult. setBorder (BorderFactory.createRaisedBevelBorderO); 
btnCancel.setBorder (BorderFactory.createRaisedBevelBorderO); 

this.getContentPane().add(lblName, null); 
this.getContentPane().add(txtName, null); 
this.getContentPane().add(lblRelation 1, null); 
this.getContentPane0.add(cmbRelationl, null); 
this.getContentPane0.add(cmbRelation2, null); 
this.getContentPane0.add0blRelation2, null); 

if (test.window.isDesign()){ 
this.getContentPane().add(cmbAttribute,null); 

} 

else{ 
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this.getContentPane().add(txtJoinAtList, null); 

} 

this.getContentPane().add(lblJoinAtList, null); 
this.getContentPane().add(chkResult, null); 
this.getContentPane().add(btnCancel, null); 
this.getContentPane().add(btnOK, null); 

this.setBounds(100,100,210,150); 
this.show(true); 

} 


/* Set Methods */ 

/** 

* Sets the first relation of the operator 

* ©parameter relation 1 (String) 

**f 

public void setRelationl (String relationl){ 
this.relationl = relation 1; 

} 


/** 

* Sets the second relation of the operator 

* ©parameter relation2 (String) 

**/ 

public void setRelation2 (String relation2){ 
this.relation2 = relation2; 

} 


* Sets the name of the operator 

* ©parameter name (String) 

**! 

public void setName (String name){ 
this.name = name; 

} 


* Sets the join attribute list of the operator 

* ©parameter joinAtList (String) 

**/ 

public void setJoinAtList (String join AtList) { 
this.joinAtList = joinAtList; 

} 
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Get Methods 



*/ 


* Gets the number of the input nodes of the operator 
**! 

public int getnumberOfNodes(){ 
return this.NO_INPlJT_NODES; 

} 


/** 

* Gets the type of the operator 
**! 

public String getOperatorType(){ 
return this.OPERATOR_TYPE; 

} 


* Gets the first relationof the operator 
**! 

public String getRelationl (){ 
return this.relationl; 

} 


* Gets the second relation of the operator 
**! 

public String getRelation2 (){ 
return this.relationl; 

} 


* Gets the name of the operator 
**! 

public String getName (){ 
return this.name; 

} 


!** 

* Gets the join attribute list of the operator 

public String getJoinAtList (){ 
return this.joinAtList; 

} 
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/* WINDOW ACTIVATIONS */ 

/** 

* The window listener methods 

* @param event (WindowEvent) 

**/ 

public void windowClosing (WindowEvent event) {System.exit(0);} 

public void window Activated (WindowEvent event) {} 

public void windowClosed (WindowEvent event) {} 

public void windowDeactivated (WindowEvent event) {} 

public void windowDeiconified (WindowEvent event) {} 

public void windowiconified (WindowEvent event) {} 

public void windowOpened (WindowEvent event) {} 


* button okay action performed 

* Takes the information entered for the operator. Creates a new operator and 

* calls add or change method of the draw class. And sends new operator 

* information there to be added to the list. 

* @param e (ActionEvent) 

void btnOK_actionPerformed(ActionEvent e) { 
if(chkResult.isSelected()) { 
display = true; 

} 

else{ 

display = false; 

} 

setName (txtName.getTextO); 

setRelation 1 ((String)cmbRelation 1 .getSelectedItem()); 

setRelation2((String)cmbRelation2.getSelectedItem()); 

if (test.window.isDesign()){ 
setJoinAtList((String)cmbAttribute.getSelectedItem()); 

} 

else { 

if (txtJoinAtList.getText().equals("")) { 

test.window.message.setMessageC'You did not enter the Eqjoin attribute"); 
test.window.message.show(true); 

} 

else { 

setJoinAtList(txtJoinAtList.getText()); 

} 

} 

String [] input = {getRelationl(),getRelation2(),getJoinAtList(),"none"}; 
buildQueryO; 
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if (test.window.isDesign()){ 
test.window.designQueries.addElement(query); 

} 

else { 

if (whoIsCalling){ 
test-window.cnvDFQL.change 

(current,indexNum,x,y,getName(),getnumberOfNodes(), 
input,display, getOperatorType(),query); 

else{ 

test-window.cnvDFQL.add 

(x,y,getName(),getnumberOfNodes(),input,display, 
getOperatorTypeO, query); 

} 

} 

this.disposeO; 

} 


j** 

* Loads the relations with the tables of the selected database and previously 

* created operators. 

void loadSelectO { 
if(! whoIsCalling) { 

txtName.setText("Eqjoin"+test.window.Counter[6]++); 

} 

Vector deneme = test.window.currentDatabase.getTableNames(); 
for (int index = 0; index < deneme.size(); index-H-) { 
cmbRelation 1 .addIteni((String) denenie.elementAt(index)); 
cmbRelation2.addItem((String) deneme.elementAt(index)); 

} 

for (int xi = 0; xi <test.window.cnvDFQL.numOfOperators;xi-H-){ 
cmbRelation 1 .addItem(test.window.cnvDFQL.operators[xi] .name); 
cmbRelation2.addItem(test.window.cnvDFQL.operators[xi].name); 

cmbRelation 1 .removeItem(name); 
cmbRelation2.removeItem(name); 

if (relation 1= null) 
cmbRelation 1 .setSelectedIndex(0); 
else 

cmbRelation 1 .setSelectedItem(relation 1); 
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if (relation2= null) 
cmbRelation2.setSelectedIndex(0); 
else 

cmbRelation2.setSelectedItem(relation2); 

} 


* button cancel action performed 

* terminates this frame without creating an operator, decrements the counter 

* @param e (ActionEvent) 

**! 

void btnCancel_actionPerformed(ActionEvent e) { 
test.window.Counter[6]--; 
this.disposeQ; 

} 


* This portion of the code produces the SQL query for this operator according 

* to the information entered by user. 

**/ 

public void buildQueryO { 

String checkRelation = isOtherOperator (relation 1); 

Vector attList2 = new Vector(); 

String queryPre = "select distinct si.*"; 
if (checkRelation = null) { 
query = " from" + relationl+" si,"; 

} 

else { 

query = " from " + "(" +checkRelation + ") si,"; 

} 

checkRelation = isOtherOperator(relation2); 
try { 

if (checkRelation == null) { 
query = query + relation2+" s2"; 

attList2 = test.window.currentDatabase.getTableAttributeNames(relation2); 

} 

else { 

query = query + "(" +checkRelation + ") s2"; 

Table temp = test.window.currentDatabase.executeQuery(checkRelation); 
attList2 = temp.getAttributeNamesO; 

} 

if (!(joinAtList.equals(""))) { 

query = query + " where si." + joinAtList+" = s2."+joinAtList; 
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} 


int deneme = attList2.indexOf(joinAtList); 
if (deneme >= 0){ 

for (int dup = 0; dup<attList2.size(); dup-H-){ 
if (dup != deneme) { 

queryPre = queryPre + ", s2."+(String)attList2.elementAt(dup); 

) 

} 

else { 

queryPre = queiyPre + ", s2.*"; 

} 

query = queryPre + query; 

} 

catch (Exception e){ 

System.out.println(e.getMessage()); 

} 


* This portion of the code looks for the type of the relations, if they are 

* tables it returns null, otherwise if is another operator, it returns the 

* queiy of the operator which the current operator related to. 

public String isOtherOperator (String type) { 

String result = null; 

for (int index = 0; index < test.window.DFQLQuery.size(); index-H-) { 
Operator temp = (Operator) test.window.DFQLQuery.elementAt(index); 
if (type.equalsIgnoreCase(temp.name)) { 
result = temp.query; 
break; 

} 

} 

return result; 

} 


/** 

* This function is used to fill the combo boxes with the selection alternatives 

* if this operator is created as a part of a user defined operator then the 

* relation and condition combo boxes are filled with user defined operator 

* input items. 

private void loadDesign(){ 
txtName.setText(name); 

for (int index = 0 ; index < test.window.designRelation.size(); index++) { 
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cmbRelation 1 .addItem((String) test.window.designRelation.elementAt 

(index)); 

cmbRelation2.addItem((String) test.window.designRelation.elementAt 

(index)); 


} 


for (int opindex = 0 ; opindex < test.window.designOps.size(); opIndex-H-) { 
if (!name.equalsIgnoreCase((String) test.window.designOps.elementAt 

(opLidex))){ 

cmbRelation 1 .addItem((String) test.window.designOps.elementAt 

(opindex)); 

cmbRelation2.addItem((String) test.window.designOps.elementAt 

(opindex)); 


}} 


for (int attindex = 0; attindex < test.window.designAttribute.size(); 
attIndex-i-+){ 

cmbAttribute.addItem((String) test.window.designAttribute.elementAt 
(attindex)); 

} 

} 

} 

OperatorGroupCntJava 


package ThesisGUI; 

import j ava.awt.event. *; 
import java.io.*; 
import java.util.*; 
import java.awt.*; 
import javax.swing.*; 
import java.util. Vector; 
import javax.accessibility.*; 
import javax.swing.UIManager; 

* This frame is used to allow the user to enter the operator information 

* for group count operator. It also allwos user to change the information 

* previously entered. 

* AUTHOR : IS & BA 

public class OperatorGroupCnt extends JFrame implements WindowListener{ 

!** Type of the operator (constant) **/ 

final static String OPERATOR_TYPE = "GroupCnt"; 
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/** Input node number of the operator (constant) **/ 
final static int NO_INPUT_NODES = 3; 

/** X coordinate of the operator**/ 
private int x; 

/** Y coordinate of the operator**/ 
private int y; 

/** name of the operator**/ 
private String name; 

/** input node relation**/ 
private String relation; 

/** group attribute list**/ 
private String groupAtt; 

/** count attribute list**/ 
private String countAtt; 

/** display information for the operator**/ 
private boolean display = false; 

/** SQL query of the operator**/ 
private String query; 

/** Specify why this frame is called (to create a new one (false) 
* or change the current operator (true)**/ 
private boolean whoIsCalling = false; 

/** The index of the operator in the Operators list **/ 
private int indexNum; 

/** The index of the operator in the DFQLList**/ 
private int current; 

/** name label of the frame**/ 

JLabel IblName = new JLabel(); 

/** relation label of the frame**/ 

JLabel IblRelation = new JLabel(); 

/** group attribute list label of the frame**/ 

JLabel IblGroupAtt = new JLabel(); 
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/** count attribute list label of the frame**/ 

JLabel IblCountAtt = new JLabelQ; 

/** text area to enter the name of the operator default diff#**/ 
JTextField txtName = new JTextField(); 

/** Okay button to confirm the info entered**/ 

JButton btnOK = new JButton(); 

/** check box for display information**/ 

JCheckBox chkResult = new JCheckBoxQ; 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelationl = new JComboBox(); 

/** Button cancel to cancel this operation**/ 

JButton btnCancel = new JButton(); 

/** text area to enter the group attribute list of the operator **/ 
JTextField txtGroupAtt = new JTextFieldQ; 

/** Combo box lists the available attributes that can be 

* related to this operator**/ 

JComboBox cmbGrpAttribute = new JComboBoxQ; 

/** text area to enter the count attribute list of the operator **/ 
JTextField txtCountAtt = new JTextFieldQ; 

/** Combo box lists the available attributes that can be 

* related to this operator**/ 

JComboBox cmbCntAttribute = new JComboBoxQ; 

/* CONSTRUCTOR */ 

/** 

* Default constructor 

* ©parameters X and Y (integer) coordinates of the operator 

public OperatorGroupCnt(int x, int y) { 
try { 

this.x = x; 
this.y = y; 
jblnitQ; 

} 

catch(Exception e) { 
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e.printStackTraceQ; 

} 

} 


* Constructor with all parameters 

* ©parameters @ parameters x, y, callerl, caller2 (integer), 

* name,relation, groupAtt, countAtt (String), 

* display (boolean) 


public OperatorGroupCnt(int x, int y, int callerl, int caller2. String 
String relation, String groupAtt, String countAtt, 


boolean display)! 

this.x 

= x; 

this.y 

=y; 

this.current 

= callerl; 

this.indexNum 

= caller2; 

this.whoIsCalling 

= true; 

this.name 

= name; 

this.relation 

= relation; 

this.groupAtt 

= groupAtt; 

this.countAtt 

= countAtt; 

this, display 

= display; 


name. 


txtName.setText (name); 
txtGroupAtt.setText (groupAtt); 
txtCountAtt.setText (countAtt); 
if (display)! 

chkResult.setSelected(tme); 

} 

else! 

chkResult. setSelected(false); 

} 

try ! 
jblnitO; 

} 

catch(Exception e)! 
e.printStackTraceO; 

} 

} 
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!** 

* Design constructor 

* ©parameters name 
**! 

public OperatorGroupCnt(String name) { 
try { 

this.name = name; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceQ; 

} 

} 


/* INITIATE METHOD */ 

/** 


* The initiation 

* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 


private void jblnit() throws 
IblName.setText 
this.setTitle 
IblRelation.setText 
IblGroup Att. setT ext 
IblCountAtt.setText 
btnOK-setText 
chkResult.setText 
btnCancel.setText 


Exception { 
("Name"); 
("GroupCnt"); 
("Relation"); 
("Group Att."); 
("Count Att."); 
("OK"); 
("Display"); 
("Cancel"); 


IblName.setBounds 

IblRelation. setBounds 

lblGroupAtt.setBounds 

IblCountAtt.setBounds 

txtName.setBounds 

txtGroupAtt.setBounds 

cmbGrpAttribute.setBounds 

txtCountAtt. setBounds 

cmbCntAttribute.setBounds 

btnOK.setBounds 

chkResult.setBounds 

cmbRelation 1 .setBounds 

btnCancel.setBounds 


(new Rectangle(4, 2, 93, 18)); 

(new Rectangle(4,27,93,18)); 
(new Rectangle(4,52,93,18)); 
(new Rectangle(4,75,93,18)); 
(new Rectangle(80,2,114,17)); 
(new Rectangle(80,53,114,17)); 
(new Rectangle(80,53, 114,17)); 
(new Rectangle(80,76, 114,17)); 
(new Rectangle(80,76, 114, 17)); 
(new Rectangle(144,101,49,22)); 
(new Rectangle(4,101, 60,22)); 
(new Rectangle(80,28, 114, 17)); 
(new Rectangle(74,101,60, 23)); 


if (test.window.isDesign()){ 
loadDesignO; 
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} 

else{ loadSelectQ; 

} 

btnOK.addActionListener(new java.awt.event.ActionListenerQ { 
public void actionPerformed(ActionEvent e) { 
btnOK_actionPerformed(e); 

}}); 

btnCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnCancel_actionPerformed(e); 

}}); 

btnOK.setBorder (BorderFactory.createRaisedBevelBorder()); 

btnCancel.setBorder (BorderFactory.createRaisedBevelBorderO); 

chkResult,setBorder (BorderFactory.createRaisedBevelBorder()); 

chkResult.setBorderPainted (true); 

cmbRelationl.setBorder (null); 

btnCancel.setFont (new java.awt.Font("Dialog", 0,11)); 
btnOK.setFont (new java.awt.Font("Dialog", 0,11)); 
chkResult.setFont (new java.awt.Font("Dialog", 0,11)); 

this.getContentPane().setLayout(null); 
this.getContentPane0.add(lblName, null); 
this.getContentPane().add(txtNanie, null); 
this.getContentPane().add(lblRelation, null); 
this.getContentPane().add(cmbRelationl,null); 
if (test.window.isDesign()){ 
this.getContentPane().add(cnibGrpAttribute,null); 
this.getContentPane0.add(cmbCntAttribute,null); 

} 

else { 

this.getContentPane().add(txtGroupAtt, null); 
this.getContentPane().add(txtCountAtt, null); 

} 

this.getContentPane().add(lblGroupAtt, null); 
this.getContentPane().add(lblCountAtt, null); 
this.getContentPane().add(chkResult, null); 
this.getContentPane().add(btnCancel, null); 
this.getContentPane(XaddO)tnOK, null); 

this.setBounds(100,100,210,160); 
this.show(true);} 
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Set Methods 


/* 


*/ 


* Sets the relation of the operator 

* ©parameter relation (String) 

**/ 

public void setRelation (String relation) { 
this.relation = relation; 

} 


/** 

* Sets the group attribute list 

* ©parameter groupAtt (String) 

public void setGroupAtt (String groupAtt) { 
this.groupAtt = groupAtt; 

} 


/** 

* Sets the count attribute list 

* ©parameter countAtt (String) 

public void setCountAtt (String countAtt) { 
this.countAtt = countAtt; 

} 


/** 

* Sets the name of the operator 

* ©parameter name (String) 

**/ 

public void setName (String name){ 
this.name = name; 

} 


/** 

* gets the input node number of the operator 

**f 

public int getnumberOfNodes(){ 
return this.NO_INPUT_NODES; 

} 


* gets the operator type of the operator 
**/ 

public String getOperatorType(){ 
return this.OPERATOR_TYPE;} 
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* gets the relation of the operator 

public String getRelation (){ 
return this.relation; 

} 


* gets the group attribute list of the operator 

public String getGroupAtt (){ 
return this.groupAtt; 

} 


* gets the count attribute list of the operator 

public String getCountAtt (){ 
return this.countAtt; 

} 


* gets the name of the operator 

**/ 


public String getName (){ 
return this.name; 

} 


/* WINDOW ACTIVATIONS */ 


* The window listener methods 

* @param event (WindowEvent) 

**/ 

public void windowClosing 
public void window Activated 
public void windowClosed 
public void windowDeactivated 
public void windowDeiconified 
public void windowiconified 
public void windowOpened 


(WindowEvent event) {System.exit(O);} 
(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 
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f** 

* button okay action performed 

* Takes the information entered for the operator. Creates a new operator and 

* calls add or change method of the draw class. And sends new operator 

* information there to be added to the list. 

* @param e (ActionEvent) 

void btnOK_actionPerformed(ActionEvent e) { 
if(chkResult.isSelected()) { 
display = true; 

} 

else{ 

display = false; 

} 

setName(txtName.getText()); 

setRelation((String)cmbRelationl.getSelectedItem()); 
if (test.window.isDesign()){ 

setGroupAtt((String)cmbGrpAttribute.getSelectedItem()); 

setCountAtt((String)cmbCntAttribute.getSelectedItem()); 

} 

else{ 

setGroupAtt(txtGroupAtt.getText()); 
setCountAtt(txtCountAtt.getText()); 
if (txtCountAtt.getText().equals("")) { 

test.window.message.setMessage("You did not enter the count attribute"); 
test.window.message.show(trae); 

} 

} 

String [] input = {getRelation(),getGroupAtt(),getCountAtt(),"none"}; 
buildQueryO; 

if (test.window.isDesign()){ 
test.window.designQueries.addElement(query); 

} 

else { 

if (whoIsCalling){ 
test.window.cnvDFQL.change 

(current,indexNum,x,y,getName(),getnumberOfNodes(), 
input,display, getOperatorType(),query); 

} 
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else{ 

test.window.cnvDFQL.add 

(x,y,getName(),getnumberOfNodes(),input,display, 
getOperatorTypeQ, query); 

} 

} 

this.disposeO; 

} 


* Loads the relations with the tables of the selected database and previously 

* created operators. 

void loadSelectO { 

Vector deneme = test.window.currentDatabase.getTableNames(); 
if(!whoIsCalling){ 

txtNaine.setText("GroupCnt"+test.window.Counter[5]-H-); 

} 

for (int index = 0; index < deneme.size(); index-H-) { 
cmbRelation 1 .addItem((String) deneme.elementAt(index)); 

} 

for (int xi = 0; xi <test.window.cnvDFQL.numOfOperators;xi-H-){ 
cmbRelationl.addItem(test.window.cnvDFQL.operators[xi].name); 

} 

cmbRelation 1 .removeItem(name); 

if (relation— null) 
cmbRelation 1 .setSelectedlndex(O); 
else 

cmbRelation 1 .setSelectedItem(relation); 


* button cancel action performed 

* terminates this frame without creating an operator, decrements the counter 

* @param e (ActionEvent) 

**/ 

void btnCancel_actionPerformed(ActionEvent e) { 
test.window.Counter[5]~; 
this.disposeO; 

} 
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* This portion of the code produces the SQL query for this operator according 

* to the information entered by user. 

**j 

public void buildQuery(){ 

String checkRelation = isOtherOperator (relation); 
if (countAtt.equals("")){ 

query = "select distinct" + groupAtt + ", count (*)"; 

} 

else{ 

query = "select distinct " + groupAtt + ", count (*) As " + countAtt; 

} 

if (checkRelation = null) { 
query = query +" from " + relation; 

} 

else { 

query = query +" from " +"(" -fcheckRelation + ")"; 

} 

query = queiy + " group by " + groupAtt; 

} 


!** 

* This portion of the code looks for the type of the relations, if they are 

* tables it returns null, otherwise if is another operator, it returns the 

* query of the operator which the current operator related to. 

**/ 

public String isOtherOperator (String type) { 

String result = null; 

for (int index = 0; index < test.window.DFQLQuery.size(); index-H-) { 
Operator temp = (Operator) test.window.DFQLQuery.elementAt(index); 
if (type.equalsIgnoreCase(temp.name)) { 
result = temp.query; 
break; 

} 

} 

return result; 

} 


/** 

* This function is used to fill the combo boxes with the selection alternatives 

* if this operator is created as a part of a user defined operator then the 

* relation and condition combo boxes are filled with user defined operator 

* input items. 
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private void loaciDesign(){ 
txtName.setT ext(name); 

for (int index = 0 ; index < test.window.designRelation.size(); index-H-) { 
cmbRelation 1 .addItem((String) test.window.designRelation.elementAt 

(index)); 


} 


for (int opindex = 0; opindex < test.window.designOps.size(); opIndex-H-) { 
if (!name.equalsIgnoreCase((String) test.window.designOps.elementAt 

(opindex))) 

cmbRelation l.addItem((String) test.window.designOps.elementAt 

(opindex)); 


} 


for (int attindex = 0; attindex < test.window.designAttribute.size(); 
attIndex-H-){ 

cmbGrpAttribute.addItem((String) test.window.designAttribute.eIementAt 

(attindex)); 

cmbCntAttribute.addItem((String) test.window.designAttribute.elementAt 

(attbidex)); 

} 

} 

} 

16 . OperatorGrpAllSatJava 


package ThesisGUI; 

import j ava. awt.event. *; 
import javado.*; 
import java.util.*; 
import java.awt.*; 
import javax.swing.*; 
import java.util. Vector; 
import javax.accessibility.*; 
import javax.swing.UIManager; 

* This frame is used to allow the user to enter the operator information 

* for group all satisfy operator. It also allwos user to change the information 

* previously entered. 

* AUTHOR : IS & BA 

public class OperatorGrpAllSat extends JFrame implements WindowListener{ 
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/** Type of the operator (constant) **/ 

final static String OPERATOR_TYPE = "GrpAllSat"; 

/** Input node number of the operator (constant) **/ 
final static int NO_INPUT_NODES = 3; 

/** X coordinate of the operator**/ 
private int x; 

/** Y coordinate of the operator**/ 
private int y; 

/** name of the operator**/ 
private String name; 

/** input node relation**/ 
private String relation; 

/** group attribute list**/ 
private String groupAtt; 

/** groupping condition **/ 
private String condition; 

/** display information for the operator**/ 
private boolean display = false; 

/** SQL query of the operator**/ 
private String query; 

/** Specify why this frame is called (to create a new one (false) 
* or change the current operator (true)**/ 
private boolean whoIsCalling = false; 

/** The index of the operator in the Operators list **/ 
private int indexNum; 

/** The index of the operator in the DFQLList**/ 
private int current; 

/** name label of the frame**/ 

JLabel IblName = new JLabel(); 

/** relation label of the frame**/ 

JLabel IblRelation = new JLabel(); 
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/** group attribute list label of the frame**/ 

JLabel IblGroupAtt = new JLabel(); 

/** count attribute list label of the frame**/ 

JLabel IblCondition = new JLabel(); 

/** text area to enter the name of the operator default diff#**/ 
JTextField txtName = new JTextFieldQ; 

/** Okay button to confirm the info entered**/ 

JButton btnOK = new JButton(); 

/** check box for display information**/ 

JCheckBox chkResult = new JCheckBoxQ; 

/** Cornbo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelationl = new JComboBoxQ; 

/** Button cancel to cancel this operation**/ 

JButton btnCancel = new JButtonQ; 

/** text area to enter the group attribute list of the operator **/ 
JTextField txtGroupAtt = new JTextField(); 

/** Combo box lists the available attributes that can be 

* related to this operator**/ 

JComboBox cmbGroupAtt = new JComboBox(); 

/** text area to enter the count attribute list of the operator **/ 
JTextField txtCondition = new JTextField(); 

/** Combo box lists the available attributes that can be 

* related to this operator**/ 

JComboBox cmbCondition = new JComboBox(); 

/* CONSTRUCTOR */ 

/** ■ 

* Default constmctor 

* ©parameters X and Y (integer) coordinates of the operator 

public OperatorGrpAllSat(int x, int y) { 
try { 

this.x = x; 
this.y = y; 
jblnitO; 
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} 

catch(Exception e) { 
e.printStackTraceO; 

} 


} 


* Constructor with all parameters 

* ©parameters @ parameters x, y, caller 1, caller2 (integer), 

* name,relation, groupAtt, condition (String), 

* display (boolean) 

**! 

public OperatorGrpAllSat(int x, int y, int callerl, int caller2. String name. 
String relation. String groupAtt, String condition, 
boolean display) { 


this.x 

this.y 

this.current 

this.indexNum 

this.whoIsCalling 

this.name 

this.relation 

this.groupAtt 

this.condition 

this.display 


= x; 

= y; 

= callerl; 

= caller2; 

= true; 

= name; 

= relation; 

= groupAtt; 
= condition; 
= display; 


txtName.setText 

txtGroupAtt.setText 

txtCondition.setText 


(name); 

(groupAtt); 

(condition); 


if (display) { 

chkResult.setSelected(trae); 

} 

else{ 

chkResult.setSelected(false); 

} 

try { 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 
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* Design constructor 

* ©parameters name 

public OperatorGrpAllSat(String name) { 
try { 

this.name = name; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 



INTTIATE METHOD 


*/ 


* The initiation 

* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 


private void jblnit() throws 
IblName.setText 
this.setTitle 
IblRelation.setText 
IblGroupAtt.setText 
IblCondition.setText 
btnOK.setText 
chkResult.setText 
btnCancel. setT ext 


Exception { 
("Name"); 
("GrpAllSat"); 
("Relation"); 
("Group Att."); 
("Condition"); 
("OK"); 
("Display"); 
("Cancel"); 


IblName.setBounds 

IblRelation.setBounds 

IblGroupAtt.setBounds 

IblCondition.setBounds 

txtName.setBounds 

txtGroupAtt.setBounds 

cmbGroupAtt.setBounds 

txtCondition.setBounds 

cmbCondition.setBoimds 

btnOK.setBounds 

chkResult.setBounds 

cmbRelation 1 .setBounds 

btnCancel.setBounds 


(new Rectangle(4, 2,93, 18)); 
(new Rectangle(4,27,93,18)); 
(new Rectangle(3, 53,93, 18)); 
(new Rectangle(3, 76, 93, 18)); 
(new Rectangle(80,2, 114, 17)); 
(new Rectangle(79,54,114, 17)); 
(new Rectangle(79, 54,114, 17)); 
(new Rectangle(79,77,114, 17)); 
(new Rectangle(79,77,114,17)); 
(new Rectangle(143,104, 50, 22)); 
(new Rectangle(3, 104, 62, 22)); 
(new Rectangle(80, 28,114, 17)); 
(new Rectangle(74, 104, 60, 23)); 


if (test.window.isDesign()){ 
loadDesignO; 
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} 

else{ 

loadSelectQ; 

} 

btnOK.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnOK_actionPeifonned(e); 

}}); 

btnCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e).{ 
btnCancel_actionPerfonned(e); 

}}); 

chkResult.setFont (new java.awt.Font("Dialog", 0, 11)); 
btnOK.setFont (new java.awt.Font("Dialog", 0,11)); 
btnCancel.setFont (new java.awt.Font("Dialog", 0, 11)); 

btnCancel.setBorder (BorderFactory.createRaisedBevelBorder()); 

btnOK.setBorder (BorderFactory.createRaisedBevelBorderO); 

chkResult-setBorder (BorderFactory.createRaisedBevelBorderO); 

chkResult.setBorderPainted (true); 

cmbRelation 1 .setBorder (null); 

this.getContentPane().setLayout (null); 

this.getContentPane().add(lbIName, null); 
this.getContentPaneO. add(txtName, null); 
this.getContentPane().add(lblRelation, null); 
this.getContentPaneO. add(cnibRelation 1, null); 
this.getContentPane().add(lblGroupAtt, null); 
this.getContentPane().add(lblCondition, null); 
if(test.window.isDesign()) { 
this.getContentPane().add(cmbGfroupAtt,null); 
this.getContentPane().add(cmbCondition,null); 

} 

else{ 

this.getContentPane().add(txtGroupAtt, null); 
this.getContentPane().add(txtCondition, null); 

} 

this.getContentPaneO• add(chkResult, null); 
this.getContentPane().add(btnCancel, null); 
this.getContentPane().add(btnOK, null); 

this.setBounds(100,100,210,160); 
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this.show(true); 

} 


/* Set Methods */ 

* Sets the relation of the operator 

* ©parameter relation (String) 

**/ 

public void setRelation (String relation) { 
this.relation = relation; 

} 

* Sets the group attribute list of the operator 

* ©parameter groupAtt (String) 

**/ 

public void setGroupAtt (String groupAtt){ 
this.groupAtt = groupAtt; 

} 


* Sets the condition of the operator 

* ©parameter condition (String) 

public void setCondition (String condition) { 
this.condition = condition; 

} 


!** 

* Sets the name of the operator 

* ©parameter name (String) 

**! 

public void setName (String name){ 
this.name = name; 

1 


/* Get Methods */ 

/** 

* gets the input number of the operator 

public int getnumberOfNodes(){ 
return this.NO_INPUT_NODES; 

} 
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!** 

* gets the type of the operator 

public String getOperatorType(){ 
return this.OPERATOR_TYPE; 

} 


* gets the relation of the operator 
**! 

public String getRelation (){ 
return this.relation; 

} 


* gets the group Attribute list of the operator 
**! 

public String getGroupAtt (){ 
return this.groupAtt; 

} 


* gets the condition of the operator 

public String getCondition (){ 
return this.condition; 

} 


!** 

* gets the name of the operator 
**/ 

public String getName (){ 
return this.name; 

} 


/* WINDOW ACTIVATIONS */ 

/** 


* The window listener methods 

* @param event (WindowEvent) 
**/ 

public void windowClosing 
public void window Activated 
public void windowClosed 
public void windowDeactivated 
public void windowDeiconified 
public void windowiconified 


(WindowEvent event) {System.exit(0);} 
(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 
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public void windowOpened (WindowEvent event) {} 

/** 

* button okay action performed 

* Takes the information entered for the operator. Creates a new operator and 

* calls add or change method of the draw class. And sends new operator 

* information there to be added to the list. 

* @param e (ActionEvent) 

**/ 

void btnOK_actionPerformed(ActionEvent e) { 
if(chkResult.isSelected()) { 
display = tme; 

} 

else{ 

display = false; 

} 

setName(txtName.getText()); 

setRelation((String)cmbRelation 1 .getSelectedItem()); 
if (test.window.isDesign()){ 
setGroupAtt((String)cmbGroupAtt.getSelectedItem()); 
setCondition((String)cmbCondition.getSelectedItem()); 

} 

else{ 

setGroupAtt(txtGroupAtt.getText()); 
if (txtCondition.getText().equals("")) { 

test.window.message.setMessage("You did not enter the condition"); 
test.window.message.show(true); 

} 

setCondition(txtCondition.getText()); 

} 

String [] input = {getRelation(),getGroupAtt(),getCondition(),"none"}; 
buildQueryO; 

if (test.window.isDesign()){ 
test.window.designQueries.addElement(query); 

} 

else { 

if (whoIsCalling){ 
test.window.cnvDFQL.change 

(current,indexNum,x,y,getName(),gemumberOfNodes(), 
input,display, getOperatorType(),query); 

else{ 

test.window.cnvDFQL.add 

(x,y,getName(),gemumberOfNodes(),input,display, 
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getOperatorTypeO, query); 

} 

} 

this.disposeO; 

} 

!** 

* Loads the relations with the tables of the selected database and previously 

* created operators. 

**/ 

void loadSelectO { 

Vector deneme = test.window.currentDatabase.getTableNames(); 
if(! whoIsCalling) { 

txtName.setText("GrpAllSat"+test.window.Counter[7]-H-); 

} 

for (int index = 0 ; index < deneme.size(); index-H-) { 
cmbRelation 1 .addItem((String) deneme.elementAt(index)); 

} 

for (int xi = 0; xi <test.window.cnvDFQL.numOfOperators;xi-H-){ 
cmbRelationl.addItem(test.window.cnvDFQL.operators[xi].naine); 

} 

cmbRelation 1 .removeltem(name); 

if (relation== null) 
cmbRelationl.setSelectedIndex(0); 
else 

cmbRelationl.setSelectedItem(relation); 


f** 

* button cancel action performed 

* terminates this frame without creating an operator, decrements the counter 

* @param e (ActionEvent) 

void btnCancel_actionPerformed(ActionEvent e) { 
test.window.Counter[7]--; 
this.disposeO; 

} 
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* This portion of the code produces the SQL query for this operator according 

* to the information entered by user. 

**! 

public void buildQuery(){ 

String checkRelation = isOtherOperator (relation); 
queiy = "select distinct" + groupAtt; 

if (checkRelation = null) { 
query = query + " from" + relation; 

} 

else { 

query = query + " from" +"(" +checkRelation + ")"; 

} 

if (!condition.equals("")){ 

query = query + " where" + condition; 

} 

query = query + " group by" + groupAtt; 

} 


* This portion of the code looks for the type of the relations, if they are 

* tables it returns null, otherwise if is another operator, it returns the 

* query of the operator which the current operator related to. 

public String isOtherOperator (String type) { 

String result = null; 

for (int index = 0; index < test.window.DFQLQuery.size(); index++) { 
Operator temp = (Operator) test.window.DFQLQuery.elementAt(index); 
if (type.equalsIgnoreCase(temp.name)) { 
result = temp.query; 
break; 

} 

} 

return result; 

} 


* This function is used to fill the combo boxes with the selection alternatives 

* if this operator is created as a part of a user defined operator then the 

* relation and condition combo boxes are filled with user defined operator 

* input items. 

**! 

private void loadDesign(){ 
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txtName.setText(name); 

for (int index = 0 ; index < test.window.designRelation.size(); index-H-) { 
cmbRelationl .addItem((String) test.window.designRelation.elementAt 

(index)); 


} 


for (int opindex = 0 ; opindex < test.window.designOps.size(); opIndex-H-) 
if (!name.equalsIgnoreCase((String) test.window.designOps.elementAt 

(opindex))) 

cmbRelation 1 .addItem((String) test.window.designOps.elementAt 

(opindex)); 


} 


{ 


for (int conindex = 0; conindex < test.window.designCondition.size(); 
conIndex-H-){ 

cmbCondition.addItem((String) test.window.designCondition.eleinentAt 

(conindex)); 


} 


for (int attindex = 0; attindex < test.window.designAttribute.size(); 
attIndex-H-){ 

cmbGroupAtt.addItem((String) test.window.designAttribute.elementAt 

(attindex)); 

} 

} 

} 


17. OperatorGrpAvg.Java 


package ThesisGUI; 

import j ava.awt.event. *; 
import java.io.*; 
import java.util.*; 
import java.awt.*; 
import javax.swing.*; 
import java.util. Vector; 
import javax.accessibility.*; 
import javax.swing.UIManager; 

/** 

* This frame is used to allow the user to enter the operator information 

* for Group Average operator. It also allwos user to change the information 

* previously entered. 

* AUTHOR : IS & BA 
**! 


191 




public class OperatorGrpAvg extends JFrame implements WindowListener{ 

/** Type of the operator (constant) **/ 

final static String OPERATOR_TYPE = "GrpAvg"; 

/** Input node number of the operator (constant) **/ 
final static int NO_INPUT_NODES = 3; 

/** X coordinate of the operator**/ 
private int x; 

/** Y coordinate of the operator**/ 
private int y; 

/** name of the operator**/ 
private String name; 

/** input node relation**/ 
private String relation; 

/** group attribute list**/ 
private String groupAtt; 

/** groupping condition **/ 
private String aggAtt; 

/** display information for the operator**/ 
private boolean display = false; 

/** SQL query of the operator**/ 
private String query; 

/** Specify why this frame is called (to create a new one (false) 

* or change the current operator (true)**/ 
private boolean whoIsCalling = false; 

/** The index of the operator in the Operators list **/ 
private int indexNum; 

/** The index of the operator in the DFQLList**/ 
private int current; 

/** name label of the frame**/ 

JLabel IblName = new JLabel(); 
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/** relation label of the frame**/ 

JLabel IblRelation = new JLabelQ; 

/** group attribute list label of the frame**/ 

JLabel IblGroupAtt = new JLabelQ; 

/** count attribute list label of the frame**/ 

JLabel IblAggAtt = new JLabelQ; 

/** text area to enter the name of the operator default diff#**/ 
JTextField txtName = new JTextFieldQ; 

/** Okay button to confirm the info entered**/ 

JButton btnOK = new JButtonQ; 

/** check box for display information**/ 

JCheckBox chkResult = new JCheckBoxQ; 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelationl = new JComboBoxQ; 

/** Button cancel to cancel this operation**/ 

JButton bmCancel = new JButtonQ; 

/** text area to enter the group attribute list of the operator **/ 
JTextField txtGroupAtt = new JTextFieldQ; 

JComboBox cmbGroupAtt = new JComboBoxQ; 

/** text area to enter the count attribute list of the operator **/ 

JT extField txtAggAtt = ne w JT extFieldQ; 

JComboBox cmbAggAtt = new JComboBoxQ; 

/* CONSTRUCTOR */ 

* Default constructor 

* ©parameters X and Y (integer) coordinates of the operator 

public OperatorGrpAvg(int x, int y) { 
try { 

this.x = x; 
this.y = y; 
jblnitQ; 

} 
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catch(Exception e) { 
e.printStackTraceO; 

} 

} 


* Constructor with all parameters 

* ©parameters @ parameters x, y, caller 1, caller2 (integer), 

* name,relation, groupAtt, aggAtt (String), 

* display (boolean) 

public OperatorGrpAvg(int x, int y, int caller 1, int caller2. String name, 
String relation. String groupAtt, String aggAtt, 
boolean display)! 


this.x 

this.y 

this.current 

this.indexNum 

this.whoIsCalling 

this.name 

this.relation 

this. groupAtt 

this.aggAtt 

this.display 


= x; 

=y; 

= caller 1; 

= caller2; 

= true; 

= name; 

= relation; 
= groupAtt; 
= aggAtt; 

= display; 


txtName.setText (name); 

txtGroupAtt-setText (groupAtt); 

txtAggAtt.setText (aggAtt); 


if (display)! 

chkResult.setSelected(true); 

} 

else! 

chkResult.setSelected(false); 

} 


try ! 
jblnitO; 

} 

catch(Exception e) ! 
e.printStackT race(); 

1 

} 
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* Design constructor 

* ©parameters name 
**/ 

public OperatorGrpAvg(String name) { 
try { 

this.name = name; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceQ; 

} • 

} 



INITIATE METHOD 


*/ 


* The initiation 

* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 

**j 


private void jblnit() throws 
IblName.setText 
this.setTitle 
IblRelation.setText 
IblGroupAtt.setText 
IblAggAtt-setTeXt 
btnOK-setText 
btnCancel.setText 
chkResult-setText 


Exception { 
("Name"); 
("GrpAvg"); 
("Relation"); 
("Group Att."); 
("Agg.Att."); 
("OK"); 
("Cancel"); 
("Display"); 


IblName.setBounds 

JblRelation.setBounds 

IblGroupAtt.setBounds 

IblAggAtt-setBounds 

txtName.setBounds 

txtGroupAtt.setBounds 

cmbGroupAtt.setBounds 

txtAggAtt-setBounds 

cmbAggAtt.setBounds 

btnOK.setBounds 

chkResult.setBounds 

cmbRelation 1 .setBounds 

btnCancel.setBounds 


(new Rectangle(4,2, 93, 18)); 

(new Rectangle(4,27,93, 18)); 
(new Rectangle(4,51,93,18)); 
(new Rectangle(4,74, 93, 18)); 
(new Rectangle(80, 2, 114, 17)); 
(new Rectangle(80, 52,114, 17)); 
(new Rectangle(80,52,114, 17)); 
(new Rectangle(80,75,114,17)); 
(new Rectangle(80,75,114,17)); 
(new Rectangle(147, 100,49, 22)); 
(new Rectangle(4,100,60,22)); 
(new Rectangle(80, 28,114, 17)); 
(new Rectangle(76,100,60,23)); 


if (test.window.isDesign()){ 
loadDesignO; 
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} 


else{ 

loadSelectO; 

} 

btnOK.addActionListener(new java.awt.event.ActionListenerQ { 
public void actionPerformed(ActionEvent e) { 
btnOK_actionPerformed(e); 

}}); 

btnCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnCancel_actionPerformed(e); 

}}); 

chkResult.setBorder (BorderFactory.createRaisedBevelBorder()); 

btnOK.setBorder (BorderFactory.createRaisedBevelBorderO); 

btnCancel.setBorder (BorderFactoiy.createRaisedBevelBorderO); 

btnOK.setFont (new java.awt.Font("Dialog", 0,11)); 
btnCancel.setFont (new java.awt.Font("Dialog", 0,11)); 
chkResult.setFont (new java.awt.Font("Dialog", 0,11)); 

chkResult.setBorderPainted (true); 

cmbRelationl.setBorder (null); 

this.getContentPane().setLayout (null); 

this.getContentPane().add(lblName, null); 
this.getContentPane().add(txtName, null); 
this.getContentPane().add(lblRelation, null); 
this.getContentPane(Xadd(cmbRelation 1, null); 
this.getContentPane(Xadd(lblGroupAtt, null); 

if(test.window.isDesign()) { 
this.getContentPane().add(cmbGroupAtt,null); 
this.getContentPane0.add(cmbAggAtt,null); 

} 

else { 

this.getContentPane().add(txtGroupAtt, null); 
this.getContentPane0.add(txtAggAtt, null); 

} 

this.getContentPane().add(lblAggAtt, null); 
this.getContentPane().add(chkResult, null); 
this.getContentPane0.add(btnOK, null); 
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this.getContentPane().add(btnCancel, null); 

this.setBounds( 100,100,210,160); 
this.show(trae); 

} 


/* Set Methods */ 

/** 

* Sets the relation of the operator 

* ©parameter relation (String) 

**! 

public void setRelation (String relation)! 
this.relation = relation; 

} 


* Sets the group aattribute list of the operator 

* ©parameter groupAtt (String) 

**! 

public void setGroupAtt (String groupAtt) { 
this.groupAtt = groupAtt; 

} 


* Sets the aggregate attribute list of the operator 

* ©parameter aggAtt (String) 

**f 

public void setAggAtt (String aggAtt) { 
this.aggAtt = aggAtt; 

} 


* Sets the name of the operator 

* ©parameter name (String) 

**! 

public void setName (String name){ 
this.name = name; 

} 


/* Get Methods */ 

* gets the input node number of the operator 
**[ 

public int getnumberOfNodes(){ 
return this.NO_INPUT_NODES; 

} 
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* gets the type of the operator 

public String getOperatorType(){ 
return this.OPERATOR_TYPE; 

} 


* gets the relation of the operator 

public. String getRelation (){ 
return this.relation; 

} 


!** 

* gets the group Attribute list of the operator 
**/ 

public String getGroupAtt (){ 
return this.groupAtt; 

} 


* gets the aggregate attribute of the operator 

public String getAggAtt (){ 
return this.aggAtt; 

} 


!** 

* gets the name of the operator 

public String getName (){ 
return this.name; 

} 


/* WINDOW ACTIVATIONS */ 

!** 


* The window listener methods 

* @param event (WindowEvent) 
**/ 

public void windowClosing 
public void window Activated 
public void windowClosed 
public void windowDeactivated 
public void windowDeiconified 


(WindowEvent event) {System.exit(O);} 
(WindowEvent event)!} 

(WindowEvent event)!} 

(WindowEvent event) j} 

(WindowEvent event)!) 
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public void windowiconified 
public void windowOpened 


(WindowEvent event) {} 
(WindowEvent event) {} 


* button okay action performed 

* Takes the information entered for the operator. Creates a new operator and 

* calls add or change method of the draw class. And sends new operator 

* information there to be added to the list. 

* @param e (ActionEvent) 

void btnOK_actionPerformed(ActionEvent e) { 
if (chkResult.isSelected()){ 
display = true; 

} 

else{ 

display = false; 

} 

setN ame(txtName.getText()); 
setRelation((String)cmbRelation 1 .getSelectedItemO); 

if (test.window.isDesign()){ 
setGroupAtt((String)cmbGroupAtt.getSelectedItem()); 
setAggAtt ((String)cmbAggAtt.getSelectedItem()); 

} 

else { 

setGroup Att(txtGroup Att.getT extQ); 
if (txtAggAtt.getText().equals("")){ 
test.window.message.setMessage 

("You did not enter the aggregate attribute"); 
test.window.message.show(true); 

} 

setAggAtt(txtAggAtt.getT ext()); 

} 

String [] input = {getRelation(),getGroupAtt(),getAggAtt(),"none"}; 
buildQueryO; 

if (test.window.isDesign()){ 
test.window.designQueries.addElement(query); 

} 

else { 

if (whoIsCalling){ 
test.window.cnvDFQL.change 

(current,indexNum,x,y,getName(),getnumberOfNodes(), 
input,display, getOperatorType(),query); 

} 
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else{ 

test.window.cnvDFQL.add 

(x,y,getName(),getnumberOfNodes(),input,display, 
getOperatorTypeO,query); 

} 

} 

this.disposeQ; 

} 


* Loads the relations with the tables of the selected database and previously 

* created operators. 

**/ 

void loadSelectQ { 

Vector deneme = test.window.currentDatabase.getTableNames(); 
if(!whoIsCalling){ 

txtName.setText("GrpAvg"+test.window.Counter[ll]-H-); 

} 

for (int index = 0 ; index < deneme.size(); index-H-) { 

cmbRelationl.addItem((String)deneme.elementAt(index)); 

} 

for (int xi = 0; xi <test.window.cnvDFQL.numOfOperators;xi-H-){ 
cmbRelation 1 .addltem(test. window.cnvDFQL.operators[xi] .name); 

cmbRelationl .removeItem(name); 

if (relation= null) 
cmbRelation 1 .setSelectedhidex(O); 
else 

cmbRelation 1 .setSelectedItem(relation); 


* button cancel action performed 

* terminates this frame without creating an operator, decrements the counter 

* @param e (ActionEvent) 

**/ 

void btnCancel_actionPerformed(ActionEvent e) { 
test.window.Counter[l 1]—; 
this.disposeO; 

} 
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* This portion of the code produces the SQL query for this operator according 

* to the information entered by user. 

public void buildQuery(){ 

String checkRelation = isOtherOperator (relation); 
query = "select distinct" + groupAtt; 

if (!aggAtt.equals("")) 

query = query + ", avg ("+aggAtt+") as avg_" + aggAtt; 

if (checkRelation == null) { 

query = query +" from" + relation; 

} 

else { 

query = query +" from" +"(" +checkRelation +")"; 

} 

query = query + " group by " + groupAtt; 

} 

* This portion of the code looks for the type of the relations, if they are 

* tables it returns null, otherwise if is another operator, it returns the 

* query of the operator which the current operator related to. 

public String isOtherOperator (String type) { 

String result = null; 

for (int index = 0; index < test.window.DFQLQuery.size(); index++) { 
Operator temp = (Operator) test.window.DFQLQuery.elementAt(index); 
if (type.equalsIgnoreCase(temp.name)) { 
result = temp.query; 
break; 

} 

} 

return result; 

} 


/** 

* This function is used to fill the combo boxes with the selection alternatives 

* if this operator is created as a part of a user defined operator then the 

* relation and condition combo boxes are filled with user defined operator 

* input items. 

private void loadDesign(){ 
txtName.setText(name); 
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for (int index = 0 ; index < test.window.designRelation.sizeQ; index-H-) 
cmbRelation 1 .addItem((String) test. window.designRelation.element At 


} 


(index)); 


{ 


for (int opindex = 0 ; oplndex < test.window.designOps.sizeO; opIndex-H-) 
if (!nanie.equalsIgnoreCase((String) test.window.designOps.elementAt 

(oplndex))) 

cmbRelation 1 .addItem((String) test.window.designOps.elementAt 


} 


(opbidex)); 


{ 


for (int attindex = 0; attindex < test.window.designAttribute.size(); 
attIndex-H-){ 

cmbGroupAtt.addItem((String) test.window.designAttribute.elementAt 

(attindex)); 

cmbAggAtt.addItem((String) test.window.designAttribute.elementAt 
(attindex)); 

} 

} 

} 

18. OperatorGrpMax.Java 


package ThesisGUI; 

import java.awt.event.*; 
import java.io.*; 
importjava.util.*; 
import java.awt.*; 
import javax.swing.*; 
import java.util. Vector; 
import javax.accessibility.*; 
import javax.swing.UIManager; 

* This frame is used to allow the user to enter the operator information 

* for group maximum operator. It also allwos user to change the information 

* previously entered. 

* AUTHOR : IS & BA 

**! 

public class OperatorGipMax extends JFrame implements WindowListener{ 

/** Type of the operator (constant) **/ 

final static String OPERATOR_TYPE = "GipMax"; 
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/** Input node number of the operator (constant) **/ 
final static int NO_INPUT_NODES = 3; 

/** X coordinate of the operator**/ 
private int x; 

/** Y coordinate of the operator**/ 
private int y; 

/** name of the operator**/ 
private String name; 

/** input node relation**/ 
private String relation; 

/** group attribute list**/ 
private String groupAtt; 

/** groupping condition **/ 
private String aggAtt; 

/** display information for the operator**/ 
private boolean display = false; 

/** SQL query of the operator**/ 
private String query; 

/** Specify why this frame is called (to create a new one (false) 
* or change the current operator (true)**/ 
private boolean whoIsCalling = false; 

/** The index of the operator in the Operators list **/ 
private int indexNum; 

/** The index of the operator in the DFQLList**/ 
private int current; 

/** name label of the frame**/ 

JLabel IblName = new JLabel(); 

/** relation label of the frame**/ 

JLabel IblRelation = new JLabel(); 

/** group attribute list label of the frame**/ 

JLabel IblGroupAtt = new JLabel(); 
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/** count attribute list label of the frame**/ 

JLabel IblAggAtt = new JLabel(); 

/** text area to enter the name of the operator default diff#**/ 
JTextField txtName = new JTextFieldQ; 

/** Okay button to confirm the info entered**/ 

JButton btnOK = new JButton(); 

/** check box for display information**/ 

JCheckBox chkResult = new JCheckBox(); 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelationl = new JComboBoxQ; 

/** Button cancel to cancel this operation**/ 

JButton btnCancel = new JButtonQ; 

/** text area to enter the group attribute list of the operator **/ 
JTextField txtGroupAtt = new JTextFieldQ; 

JComboBox cmbGroupAtt = new JComboBoxQ; 

/** text area to enter the count attribute list of the operator **/ 
JTextField txtAggAtt = new JTextFieldQ; 

JComboBox cmbAggAtt = new JComboBoxQ; 

/* CONSTRUCTOR */ 

/** 

* Default constractor 

* ©parameters X and Y (integer) coordinates of the operator 

public OperatorGrpMax(int x, int y) { 
try { 

this.x = x; 
this.y = y; 
jblnitQ; 

} 

catch(Exception e) { 
e.printStackTraceQ; 

} 

} 
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/** 

* Constructor with all parameters 

* ©parameters @ parameters x, y, callerl, caller2 (integer), 

* name,relation, groupAtt, aggAtt (String), 

* display (boolean) 


public OperatorGrpMax(int x, int y, int callerl, int caller2. String name. 
String relation, String groupAtt, String aggAtt, 
boolean display) { 


this.x 

this.y 

this.current 

this.indexNum 

this.whoIsCalling 

this.name 

this.relation 

this.groupAtt 

this.aggAtt 

this.display 


= x; 

= y; 

= callerl; 

= caller2; 

= true; 

= name; 

= relation; 
= groupAtt; 
= aggAtt; 

= display; 


txtName.setText (name); 

txtGroupAtt.setText (groupAtt); 

txtAggAtt-setText (aggAtt); 


if (display)! 

chkResult.setSelected(true); 

} 

else{ 

chkResult.setSelected(false); 

} 


try { 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 


!** 

* Design constructor 

* ©parameters name 

**f 

public OperatorGrpMax(String name) { 
try { 

this.name = name; 
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jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceQ; 

} 

} 

/* INITIATE METHOD */ 

* The initiation 

* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 

**! 

private void jblnit() throws Exception { 

IblName.setText ("Name"); 

this.setTitle ("GrpMax"); 

IblRelation.setText ("Relation"); 

IblGroupAtt-setText ("Group Att."); 

IblAggAtt.setText ("Agg.Att."); 

btnOK.setText ("OK"); 

chkResult.setText ("Display"); 

btnCancel.setText ("Cancel"); 

IblName.setBounds (new Rectangle(4,2, 93, 18)); 

IblRelation.setBounds (new Rectangle(4,27,93,18)); 

IblGroupAtt-setBounds (new Rectangle(4,50,93,18)); 

IblAggAtt-setBounds (new Rectangle(4, 73,93, 18)); 

txtName.setBounds (new Rectangle(80,2,114,17)); 

txtGroupAtt.setBounds (new Rectangle(80,51,114,17)); 

cmbGroupAtt.setBounds (new Rectangle(80, 51, 114, 17)); 

txtAggAtt.setBounds (new Rectangle(80, 74, 114,17)); 

cmbAggAtt.setBounds (new Rectangle(80,74,114,17)); 

btnOK.setBounds (new Rectangle(143,99, 52, 22)); 

chkResult-setBounds (new Rectangle(3, 99, 62, 22)); 

btnCancel.setBounds (new Rectangle(74,99,60, 23)); 

cmbRelationl.setBounds (new Rectangle(80,28,114,17)); 

if (test.window.isDesign()){ 
loadDesignO; 

} 

else { 

loadSelectO; 

} 

btnOK.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
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btnOK_actionPeiformed(e); 

)}); 

btnCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPeifonned(ActionEvent e) { 
btnCancel_actionPerformed(e); 

}}); 

chkResult.setBorderPaiiited (true); 

cmbRelationl.setBorder (null); 

chkResult.setFont (new java.awt.Font ("Dialog", 0,11)); 
btnOK.setFont (new java.awt.Font ("Dialog", 0,11)); 
btnCancel.setFont (new java.awt.Font ("Dialog", 0,11)); 

btnCancel.setBorder (BorderFactory.createRaisedBevelBorderO); 

btnOK.setBorder (BorderFactory.createRaisedBevelBorderO); 

chkResult.setBorder (BorderFactoiy.createRaisedBevelBorderO); 

this.getContentPane().setLayout(null); 
this.getContentPane().add(lblName, null); 
this.getContentPane().add(txtName, null); 
this.getContentPane().add(lblRelation, null); 
this.getContentPane().add(cmbRelation 1, null); 
this.getContentPane().add(lblGroupAtt, null); 
if(test. window.isDesignO) { 
this.getContentPane().add(cmbGroupAtt,null); 
this.getContentPane().add(cmbAggAtt, null); 

} 

else ( 

this.getContentPane().add(txtGroupAtt, null); 
this.getContentPane().add(txtAggAtt, null); 

} 

this.getContentPane().add(lblAggAtt, null); 
this.getContentPane().add(btnOK, null); 
this.getContentPane().add(clikResult, null); 
this.getContentPane().add(btnCancel, null); 
this.setBounds(100,100,210,160); 
this.show(true); 

} 
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Set Methods 



*/ 


* Sets the relation of the operator 

* ©parameter relation (String) 

public void setRelation (String relation) { 
this.relation = relation; 

} 


/** 

* Sets the group aattribute list of the operator 

* ©parameter groupAtt (String) 

**/ 

public void setGroupAtt (String groupAtt) { 
this.groupAtt = groupAtt; 

} 


* Sets the aggregate attribute list of the operator 

* ©parameter aggAtt (String) 

public void set AggAtt (String aggAtt) { 
this.aggAtt = aggAtt; 

} 


* Sets the name of the operator 

* ©parameter name (String) 

public void setName (String name){ 
this.name = name; 

} 


/* Get Methods */ 

/** 

* gets the input node number of the operator 

public int gemumberOfNodes(){ 
return this.NO_INPlJT_NODES; 

} 


* gets the type of the operator 

public String getOperatorType(){ 
return this.OPERATOR_TYPE;} 
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/** 

* gets the relation of the operator 

public String getRelation (){ 
return this.relation; 

} 

!** 

* gets the group Attribute list of the operator 
**! 

public String getGroupAtt (){ 
return this.groupAtt; 

) 

/** 

* gets the aggregate attribute of the operator 
**! 

public String getAggAtt (){ 
return this.aggAtt; 

} 

/** 

* gets the name of the operator 

public String getName (){ 
return this.name; 

} 

/* WINDOW ACTIVATIONS */ 

/** 

* The window listener methods 

* @param event (WindowEvent) 

**! 

public void windowClosing (WindowEvent event) {System.exit(0);} 

public void window Activated (WindowEvent event) {} 

public void windowClosed (WindowEvent event) {} 

public void windowDeactivated (WindowEvent event) {} 

public void windowDeiconified (WindowEvent event) {} 

public void windowiconified (WindowEvent event) {} 

public void windowOpened (WindowEvent event) {} 
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* button okay action performed 

* Takes the information entered for the operator. Creates a new operator and 

* calls add or change method of the draw class. And sends new operator 

* information there to be added to the list. 

* @param e (ActionEvent) 

**/ 

void btnOK_actionPerformed(ActionEvent e) { 
if(chkResult.isSelectedO) { 
display = true; 

} 

else{ 

display = false; 

} 

setName(txtName.getText()); 
setRelation((String)cmbRelation 1 .getSelectedItem()); 

if (test.window.isDesign()){ 
setGroupAtt((String)cmbGroupAtt.getSelectedItem()); 
setAggAtt((String)cmbAggAtt.getSelectedItem()); 

} 

else { 

setGroupAtt(txtGroupAtt.getText()); 
if (txtAggAtt.getText().equals("")) { 
test, window .message.setMessage 

("You did not enter the aggregate attribute"); 
test.window.message.show(true); 

} 

setAggAtt(txtAggAtt.getText()); 

} 

String [] input = {getRelation(),getGroupAtt(),getAggAtt(),"none"}; 
buildQueryO; 

if (test.window.isDesign()){ 
test.window.designQueries.addElement(query); 

} 

else { 

if (whoIsCalling){ 
test.window.cnvDFQL.change 

(current,indexNum,x,y,getName(),getnumberOfNodes(), 
input,display, getOperatorType(),query); 

} 

else{ 

test.window.cnvDFQL.add 

(x,y,getName(),getnumberOfNodes(),input,display, 
getOperatorTypeO, query); 

} 
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} 

this.disposeO; 

} 


!* ** 

* Loads the relations with the tables of the selected database and previously 

* created operators. 

void loadSelectO { 

Vector deneme = test.window.currentDatabase.getTableNeimesO; 
if(! whoIsCalling) { 

txtN ame. setTextC’GrpMax "+test. window.Counter [9]++); 

} 

for (int index = 0; index < deneme. sizeQ; index++) { 
cmbRelation 1 .addItem((String) deneme.elementAt(index)); 

} 

for (int xi = 0; xi <test.window.cnvDFQL.numOfOperators;xi++){ 
cmbRelationl.addItem(test.window.cnvDFQL.operators[xi].name); 

} 

cmbRelation 1 .removeltem(name); 

if (relation= null) 
cmbRelation 1. setSelectedIndex(0); 
else 

cmbRelation 1 .setSelectedItem(relation); 


/** 

* button cancel action performed 

* terminates this frame without creating an operator, decrements the counter 

* @param e (ActionEvent) 

**l 

void btnCancel_actionPerformed(ActionEvent e) { 
test.window.Counter[9]—; 
this.disposeO; 

} 


* This portion of the code produces the SQL query for this operator according 

* to the information entered by user. 

**j 

public void buildQuery(){ 

String checkRelation = isOtherOperator (relation); 
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query = "select distinct" + groupAtt; 
if (!aggAtt.equals("")) 

query = query + ", max ("+aggAtt+") as max_" + aggAtt; 

if (checkRelation == null) { 
query = query + " from " + relation; 

} 

else { 

query = query + " from " + "(" +checkRelation + 

} 

query = query +" group by" + groupAtt; 

} 

* This portion of the code looks for the type of the relations, if they are 

* tables it returns null, otherwise if is another operator, it returns the 

* query of the operator which the current operator related to. 

**/ 

public String isOtherOperator (String type) { 

String result = null; 

for (int index = 0; index < test.window.DFQLQuery.size(); index++) { 
Operator temp = (Operator) test.window.DFQLQuery.elementAt(index); 
if (type.equalsIgnoreCase(temp.name)) { 
result = temp.query; 
break; 

} 

} 

return result; 

} 


* This function is used to fill the combo boxes with the selection alternatives 

* if this operator is created as a part of a user defined operator then the 

* relation and condition combo boxes are filled with user defined operator 

* input items. 


private void loadDesign(){ 
txtName.setText(name); 

for (int index = 0 ; index < test.window.designRelation.size(); index-H-) 
cmbRelation 1 .addItem((String) test.window.designRelation.elementAt 

(index)); 


} 


{ 


for (int opindex = 0 ; opindex < test.window.designOps.size(); opIndex++) { 


212 



if (!name.equalsIgnoreCase((String) test.window.designOps.elementAt 

(opindex))) 

cmbRelationl .addItem((String) test.window.designOps.elementAt 

(opindex)); 


} 


for (int attindex = 0; attindex < test.window.designAttribute.size(); 
attIndex-H-){ 

cmbGroupAtt.addItem((String) test.window.designAttribute.elementAt 

(attindex)); 


cmbAggAtt.addItem((String) test.window.designAttribute.elementAt 
(attindex)); 

} 

} 

} 


OperatorGrpMinJava 


package ThesisGUI; 

import java.awt.event.*; 
import java.io.*; 
import java.util.*; 
import java.awt.*; 
import javax.swing.*; 
import java.util.Vector; 
import javax.accessibility.*; 
import javax.swing.UIManager; 

!** 

* This frame is used to allow the user to enter the operator information 

* for group minimum operator. It also allwos user to change the information 

* previously entered. 

* AUTHOR : IS & BA 
**/ 

public class OperatorGrpMin extends JFrame implements WindowListener{ 

/** Type of the operator (constant) **/ 

final static String OPERATOR_TYPE = "GrpMin"; 

/** Input node number of the operator (constant) **! 
final static int NO_INPUT_NODES = 3; 

/** X coordinate of the operator**/ 
private int X; 
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/** Y coordinate of the operator**/ 
private int y; 

/** name of the operator**/ 
private String name; 

/** input node relation**/ 
private String relation; 

/** group attribute list**/ 
private String groupAtt; 

/** groupping condition **/ 
private String aggAtt; 

/** display information for the operator**/ 
private boolean display = false; 

/** SQL query of the operator**/ 
private String query; 

/** Specify why this frame is called (to create a new one (false) 
* or change the current operator (true)**/ 
private boolean whoIsCalling = false; 

/** The index of the operator in the Operators list **/ 
private int indexNum; 

/** The index of the operator in the DFQLList**/ 
private int current; 

/** name label of the frame**/ 

JLabel IblName = new JLabel(); 

/** relation label of the frame**/ 

JLabel IblRelation = new JLabel(); 

/** group attribute list label of the frame**/ 

JLabel IblGroupAtt = new JLabel(); 

/** count attribute list label of the frame**/ 

JLabel IblAggAtt = new JLabel(); 

/** text area to enter the name of the operator default diff#**/ 
JTextField txtName = new JTextFieldQ; 
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/** Okay button to confirm the info entered**/ 

JButton btnOK = new JButtonQ; 

/** check box for display information**/ 

JCheckBox chkResult = new JCheckBoxQ; 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelationl = new JComboBox(); 

/** Button cancel to cancel this operation**/ 

JButton btnCancel = new JButton(); 

/** text area to enter the group attribute list of the operator **/ 
JTextField txtGroupAtt = new JTextFieldQ; 

JComboBox cmbGroupAtt = new JComboBox(); 

/** text area to enter the count attribute list of the operator **/ 
JTextField txtAggAtt = new JTextFieldQ; 

JComboBox cmbAggAtt = new JComboBoxQ; 

/* CONSTRUCTOR */ 

/** 

* Default constructor 

* ©parameters X and Y (integer) coordinates of the operator 

public OperatorGipMin(int x, int y) { 
try { 

this.x = x; 
this.y = y; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceQ; 

} 

} 
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* Constructor with all parameters 

* ©parameters @ parameters x, y, caller 1, caller2 (integer), 

* name,relation, groupAtt, aggAtt (String), 

* display (boolean) 


public OperatorGrpMin(int x, int y, int caller 1, int caller2. String 
String relation. String groupAtt, String aggAtt, 


boolean display) { 

this.x 

= x; 

this.y 

=y; 

this.current 

= caller 1; 

this.indexNum 

= caller2; 

this.whoIsCalling 

= true; 

this.name 

= name; 

this.relation 

= relation; 

this.groupAtt 

= groupAtt; 

this.aggAtt 

= aggAtt; 

this.display 

= display; 


name. 


txtName.setText (name); 

txtGroupAtt.setText (groupAtt); 

txtAggAtt.setText (aggAtt); 


if (display) { 

chkResult.setSelected(true); 

} 

else{ 

chkResult.setSelected(false); 

} 

try { 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 


* Design constructor 

* ©parameters name 

public OperatorGrpMin(String name) { 
try { 

this.name = name; 
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jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 

/* INTTIATE METHOD */ 

* The initiation 

* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 

**! 

private void jblnit() throws Exception { 

IblName.setText ("Name"); 

this.setTitle ("GrpMin"); 

IblRelation.setText ("Relation"); 

IblGroupAtt-setText ("Group Att."); 

IblAggAtt.setText ("Agg.Att."); 

btnOK.setText ("OK"); 

btnCancel.setText ("Cancel"); 

chkResult.setText ("Display"); 

IblName.setBounds (new Rectangle(4,2,93,18)); 

IblRelation.setBounds (new Rectangle(4,27,93, 18)); 

IblGroupAtt.setBounds (new Rectangle(4,50, 93,18)); 

IblAggAtt.setBounds (new Rectangle(4,73,93,18)); 

txtName.setBounds (new Rectangle(80,2,114,17)); 

txtGroupAtt.setBounds (new Rectangle(80, 51,114,17)); 

txtAggAtt.setBounds (new Rectangle(80,74,114,17)); 

cmbGroupAtt.setBounds (new Rectangle(80,51,114,17)); 

cmbAggAtt.setBounds (new Rectangle(80,74,114,17)); 

bmOK-setBounds (new Rectangle(147,100,49,22)); 

chkResult.setBounds (new Rectangle(3, 100, 59,22)); 

cmbRelationl.setBounds (new Rectangle(80,28,114,17)); 

btnCancel.setBounds (new Rectangle(125,140,60, 23)); 

btnCancel.setBounds (new Rectangle(68,100,73,23)); 

if (test.window.isDesign()){ 
loadDesignO; ’ 

} 

else { 

loadSelectO; 

} 

btnOK.addActionListener(new java.awt.event.ActionListener() { 
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public void actionPeiformed(ActionEvent e) { 
btnOK_actionPerformed(e); 

}}); 

btnCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnCancel_actionPerformed(e); 

}}); 

btnOK.setFont (new java.awt.Font("Dialog", 0,11)); 
chkResult.setFont (new java.awt.Font("Dialog", 0,11)); 
btnCancel.setFont (new java.awt.Font("Dialog", 0,11)); 

btnCancel.setBorder (BorderFactory.createRaisedBevelBorder()); 

btnOK.setBorder (BorderFactory.createRaisedBevelBorder()); 

chkResult.setBorder (BorderFactory.createRaisedBevelBorderO); 

chkResult.setBorderPainted (true); 

cmbRelationl.setBorder (null); 

this.getContentPane().setLayout (null); 

this.getContentPane().add(lblName, null); 
this.getContentPane().add(txtName, null); 
this.getContentPane0.add(lblRelation, null); 
this.getContentPane().add(cnibRelation 1, null); 
this.getContentPane(Xadd(lblGroupAtt, null); 
this.getContentPane().add(lblAggAtt,null); 
if(test. window.isDesignO) { 
this.getContentPane().add(cmbGroupAtt,null); 
this.getContentPane0.add(cmbAggAtt, null); 

} 

else { 

this.getContentPane().add(txtGroupAtt, null); 
this.getContentPane(Xadd(txtAggAtt, null); 

} 

this.getContentPane().add(chkResult, null); 
this.getContentPane0.add(btnOK, null); 
this.getContentPane().add(btnCancel, null); 

this.setBounds(100,100,210,160); 
this.show(true); 

} 
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Set Methods 


/* 

/** 


* Sets the relation of the operator 

* ©parameter relation (String) 


*/ 


public void setRelation (String relation)! 
this.relation = relation; 

} 


* Sets the group aattribute list of the operator 

* ©parameter groupAtt (String) 

public void setGroupAtt (String groupAtt) { 
this.groupAtt = groupAtt; 

} 

* Sets the aggregate attribute list of the operator 

* ©parameter aggAtt (String) 

public void setAggAtt (String aggAtt) { 
this.aggAtt = aggAtt; 

} 


/** 

* Sets the name of the operator 

* ©parameter name (String) 

**! 

public void setName (String name){ 
this.name = name; 

}. 


/* Get Methods */ 

!** 

* gets the input node number of the operator 

**! 

public int gemumberC)fNodes(){ 
return this.NO_INPUT_NODES; 

} 


* gets the type of the operator 
**/ 

public String getOperatorType(){ 
return this.OPERATOR_TYPE; } 
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* gets the relation of the operator 
**/ 

public String getRelation (){ 
return this.relation; 

} 


* gets the group Attribute list of the operator 
**/ 

public String getGroupAtt (){ 
return this.groupAtt; 

} 


* gets the aggregate attribute of the operator 
**/ 

public String getAggAtt (){ 
return this.aggAtt; 

} 


/** 

* gets the name of the operator 
**/ 

public String getName (){ 
return this.name; 

} 


/* WINDOW ACTIVATIONS */ 


/** 

* The window listener methods 

* @param event (WindowEvent) 
**/ 

public void windowClosing 
public void window Activated 
public void windowClosed 
public void windowDeactivated 
public void windowDeiconified 
public void windowiconified 
public void windowOpened 


(WindowEvent event) {System.exit(0);} 
(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 
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/** 

* button okay action performed 

* Takes the information entered for the operator. Creates a new operator and 

* calls add or change method of the draw class. And sends new operator 

* information there to be added to the list. 

* @param e (ActionEvent) 

**/ 

void btnOK_actionPerformed(ActionEvent e) { 
if(chkResult.isSelected()) { 
display = true; 

} 

else{ 

display = false; 

} 

setName(txtName.getText()); 

setRelation((String)cmbRelationl.getSelectedItem()); 

if (test.window.isDesign()){ 
setGroupAtt((String)cmbGroupAtt.getSelectedItem()); 
setAggAtt((String)cmbAggAtt.getSelectedItem()); 

} 

else { 

setGroupAtt(txtGroupAtt.getText()); 
if (txtAggAtt.getText().equals("")) { 
test.window.message.setMessage 

("You did not enter the aggregate attribute"); 
test.window.message.show(true); 

} 

setAggAtt(txtAggAtt.getText()); 


String [] input = {getRelation(),getGroupAtt(),getAggAtt(),"none"}; 

buildQueryO; 

if (test.window.isDesign()){ 

test.window.designQueries.addElement(query); 

} 

else { 

if (whoIsCalling){ 
test.window.cnvDFQL.change 

(current,indexNum,x,y,getName(),getnumberOfNodes(), 
input,display, getOperatorType(), query); 

} 

else { 

test.window.cnvDFQL.add 

(x,y,getName(),gemumberOfNodes(),input,display, 
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getOperatorTypeO, query); 


} 

} 

this.disposeO; 

} 

/** 

* Loads the relations with the tables of the selected database and previously 

* created operators. 

**! 

void loadSelectO { 

Vector deneme = test.window.currentDatabase.getTableNames(); 
if(!whoIsCalling){ 

txtName.setText("GrpMin"+test.window.Counter[10]-H-); 

} 

for (int index = 0; index < deneme.size(); index++) { 
cmbRelation 1 .addItem((String) deneme.element At(index)); 

} 

for (int xi = 0; xi <test.window.cnvDFQL.numOfOperators;xi++){ 
cmbRelation 1 .addItem(test.window.cnvDFQL.operators[xi] .name); 

} 

cmbRelation 1 .removeltem(name); 

if (relation— null) 
cmbRelation 1 .setSelectedlndex(O); 
else 

cmbRelation 1 .setSelectedItem(relation); 

} 

/** 

* button cancel action performed 

* terminates this frame without creating an operator, decrements the counter 

* @param e (ActionEvent) 

void btnCancel_actionPerformed(ActionEvent e) { 
test. window.Counter[ 10]--; 
this.disposeO; 

} 
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* This portion of the code produces the SQL query for this operator according 

* to the information entered by user. 

**/ 

public void buildQuery(){ 

String checkRelation = isOtherOperator (relation); 
query = "select distinct" + groupAtt; 

if (!aggAtt.equals("")) 

query = query +", min ("+aggAtt+") as min_" + aggAtt; 

if (checkRelation = null) { 
query = query + " from " + relation; 

} 

else { 

query = query + " from " +"(" +checkRelation + ")"; 

} 

query = query + " group by" + groupAtt; 

} 


* This portion of the code looks for the type of the relations, if they are 

* tables it returns null, otherwise if is another operator, it returns the 

* queiy of the operator which the current operator related to. 

**/ 

public String isOtherOperator (String type) { 

String result = null; 

for (int index = 0; index < test.window.DFQLQueiy.size(); index-H-) { 
Operator temp = (Operator) test.window.DFQLQuery.elementAt(index); 
if (type.equalsIgnoreCase(temp.name)) { 
result = temp.query; 
break; 

} 

} 

return result; 

} 


/** 

* This function is used to fill the combo boxes with the selection alternatives 

* if this operator is created as a part of a user defined operator then the 

* relation and condition combo boxes are filled with user defined operator 

* input items. 

**/ 

private void loadDesign(){ 
txtName.setText(name); 
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for (int index = 0 ; index < test.window.designRelation.size(); index-H-) { 
cmbRelation 1 .addItem((String) test. window.designRelation.elementAt 

(index)); 


} 


for (int opLidex = 0 ; opihdex < test.window.designOps.size(); opLidex++) { 
if (!name.equalsIgnoreCase((String) test.window.designOps.elementAt 

(opindex))) 

cmbRelation 1 .addItem((String) test-window.designOps.elementAt 

(opindex)); 


} 


for (int attindex = 0; attindex < test.window.designAttribute.size(); 
attIndex++){ 

cmbGroupAtt.addItem((String) test.window.designAttribute.elementAt 

(attindex)); 

cmbAggAtt.addItem((String) test.window.designAttribute.elementAt 
(attibidex)); 

} 

} 

} 

20. OperatorGrpNSatJava 


package ThesisGUI; 

import j ava. awt.event. *; 
import java.io.*; 
import java.util.*; 
import java.awt.*; 
import javax.swing.*; 
import java.util. Vector; 
import javax.accessibility.*; 
import javax.swing.UIManager; 

/** 

* This frame is used to allow the user to enter the operator information 

* for group number satisfy operator. It also allwos user to change 

* the information previously entered. 

* AUTHOR: IS & BA 

**! 

public class OperatorGrpNSat extends JFrame implements WindowListener{ 

/** Type of the operator (constant) **/ 

final static String OPERATOR_TYPE = "GrpNSat"; 
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/** Input node number of the operator (constant) **/ 
final static int NO_INPUT_NODES = 4; 

/** X coordinate of the operator**/ 
private int x; 

/** Y coordinate of the operator**/ 
private int y; 

/** name of the operator**/ 
private String name; 

/** input node relation**/ 
private String relation; 

/** condition number **/ 
private String number; 

/** group attribute list**/ 
private String groupAtt; 

/** groupping condition **/ 
private String condition; 

/** display information for the operator**/ 
private boolean display = false; 

/** SQL query of the operator**/ 
private String query; 

/** Specify why this frame is called (to create a new one (false) 
* or change the current operator (tme)**/ 
private boolean whoIsCalling = false; 

/** The index of the operator in the Operators list **/ 
private int indexNum; 

/** The index of the operator in the DFQLList**/ 
private int current; 

/** name label of the frame**/ 

JLabel IblName = new JLabel(); 

/** relation label of the frame**/ 

JLabel IblRelation = new JLabel(); 


225 




/** group attribute list label of the frame**/ 

JLabel IblGroupAtt = new JLabelQ; 

/** count attribute list label of the frame**/ 

JLabel IblCondition = new JLabel(); 

/** condition number of the frame**/ 

JLabel IblNumber = new JLabelQ; 

/** text area to enter the name of the operator default diff#**/ 
JTextField txtName = new JTextFieldQ; 

/** Okay button to confirm the info entered**/ 

JButton btnOK = new JButtonQ; 

/** check box for display information**/ 

JCheckBox chkResult = new JCheckBoxQ; 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelationl = new JComboBoxQ; 

/** Button cancel to cancel this operation**/ 

JButton btnCancel = new JButtonQ; 

/** text area to enter the group attribute list of the operator **/ 
JTextField txtGroupAtt = new JTextFieldQ; 

/** text area to enter the count attribute list of the operator **/ 
JTextField txtCondition = new JTextFieldQ; 

/** text area to enter the condition number of the operator **/ 
JTextField txtNumber = new JTextFieldQ; 

/* CONSTRUCTOR */ 

/** 

* Default constructor 

* ©parameters X and Y (integer) coordinates of the operator 

**! 

public OperatorGrpNSat(int x, int y) { 
try { 

this.x = x; 
this.y = y; 
jblnitQ; 

} 

catch(Exception e) { 
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e.printStackTraceO; 

} 

} 


* Constructor with all parameters 

* ©parameters @ parameters x, y, caller 1, caller2 (integer), 

* name,relation, groupAtt, condition, number (String), 

* display (boolean) 

**/ 


public OperatorGrpNSat(int x, int y, int caller 1, int caller2. String name. 
String relation. String groupAtt, String condition. 

String number, boolean display)! 


this.x 

this.y 

this.current 

this.indexNum 

this.whoIsCalling 

this.name 

this.relation 

this.groupAtt 

this.condition 

this.number 

this.display 


= x; 

= y; 

= callerl; 

= ca]ler2; 

= true; 

= name; 

= relation; 

= groupAtt; 
= condition; 
= number; 

= display; 


txtName.setText 

txtGroupAtt.setText 

txtCondition.setText 

txtNumber.setText 


(name); 

(groupAtt); 

(condition); 

(number); 


if (display)! 

chkResult.setSelected(true); 

} 

else! 

chkResult.setSelected(false); 

} 

try ! 
jbhiitO; 

} 

catch(Exception e)! 
e.printStackTraceO J 

} 

} 
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/* 


/** 


INTTIATE METHOD 


*! 


* The initiation 

* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 


private void jblnit() throws 
IblName.setText 
this.setTitle 
IblRelation.setText 
IblGroupAtt.setText 
IblCondition.setText 
IblNumber.setText 
btnOK.setText 
chlcResult-setText 
btnCancel.setText 


Exception { 
("Name"); 
("GrpNSat"); 
("Relation"); 
("Group Att."); 
("Condition"); 
("Number"); 
("OK"); 
("Display"); 
("Cancel"); 


IblName.setBounds 

IblRelation.setBounds 

IblGroupAtt-setBounds 

IblCondition.setBounds 

txtName.setBounds 

txtGroupAtt.setBounds 

txtCondition. setBounds 

btnOK.setBounds 

chkResult.setBounds 

cmbRelation 1 .setBounds 

IblNumber.setBounds 

txtNumber.setBounds 

btnCancel.setBounds 


(new Rectangle(4,2,93,18)); 
(new Rectangle(3,24, 93,18)); 
(new Rectangle(4,47, 93,18)); 
(new Rectangle(4, 70, 93, 18)); 
(new Rectangle(80, 2, 114, 17)); 
(new Rectangle(80,48,114, 17)); 
(newRectangle(80, 71, 114, 17)); 
(new Rectangle(142,117,51,22)); 
(new Rectangle(5, 117, 58, 22)); 
(new Rectangle(79,25,114,17)); 
(new Rectangle(4, 95, 68, 16)); 
(new Rectangle(80, 95, 114, 17)); 
(new Rectangle(73,117, 60, 23)); 


if(!whoIsCalling){ 

txtName.setText("GrpNSat"+test.window.Counter[8]-H-); 

} 

loadSelectO; 


btnOK.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnOK_actionPerformed(e); 

}}); 


btnCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnCancel_actionPerformed(e); 

}}); 
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chkResult.setBorderPainted 
cmbRelation 1. setBorder 


(true); 

(null); 


chkResult. setFont 

btnOK-setFont 

btnCancel.setFont 


(new java.awt.Font("Dialog", 0,11)); 
(new java.awt.Font("Dialog", 0,11)); 
(new java.awt.Font("Dialog", 0,11)); 


btnOK.setBorder (BorderFactory.createRaisedBevelBorder()); 

chkResult.setBorder (BorderFactory.createRaisedBevelBorder()); 

btnCancel.setBorder (BorderFactory.createRaisedBevelBorderO); 


this.getContentPane().setLayout (null); 
this.getContentPane().add(lblName, null); 
this.getContentPane().add(txtName, null); 
this.getContentPane().add(lblRelation, null); 
this.getContentPane().add(cmbRelationl, null); 
this.getContentPane().add(txtGroupAtt, null); 
this.getContentPane().add(lblGroupAtt, null); 
this.getContentPane().add(lblCondition, null); 
this.getContentPane().add(txtCondition, null); 
this.getContentPane().add(lblNumber, null); 
this.getContentPane().add(txtNumber, null); 
this.getContentPane().add(chkResult, null); 
this.getContentPane().add(btnCancel, null); 
this.getContentPane().add(btnOK, null); 

this.setBounds( 100,100,210,180); 
this.show(true); 

} 


/* Set Methods */ 

!** 

* Sets the relation of the operator 

* ©parameter relation (String) 

**! 

public void setRelation (String relation)! 
this.relation = relation; 

} 

/** 

* Sets the group attribute list of the operator 

* ©parameter groupAtt (String) 

**! 

public void setGroupAtt (String group Att) { 
this.groupAtt = groupAtt; 

} 
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* Sets the condition of the operator 

* ©parameter condition (String) 

public void setCondition (String condition)! 
this.condition = condition; 

} 

!** 

* Sets the condition number of the operator 

* ©parameter condition (String) 

**! 

public void setNumber (String number)! 
this.number = number; 

} 

I** 

* Sets the name of the operator 

* ©parameter name (String) 

public void setName (String name)! 
this.name = name; 

} 

/* Get Methods */ 

/** 

* gets the input number of the operator 
**/ 

public int gemumberOfNodes()! 
return this.NO_INPUT_NODES; 

} 

* gets the type of the operator 
**! 

public String getOperatorType()! 
return this.OPERATOR_TYPE; 

} 

!** 

* gets the relation of the operator 
**/ 

public String getRelation ()! 
return this.relation; 

} 
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* gets the group Attribute list of the operator 
**/ 

public String getGroupAtt (){ 
return this.groupAtt; 

} 


* gets the condition of the operator 
**! 

public String getCondition (){ 
return this.condition; 

} 


* gets the name of the operator 
**/ 

public String getName (){ 
return this.name; 

} 


I** 

* gets the condition number of the operator 
**/ 

public String getNumber (){ 
return this.number; 

} 


/* WINDOW ACTIVATIONS */ 


, * The window listener methods 
* @param event (WindowEvent) 
**/ 

public void windowClosing 
public void window Activated 
public void windowClosed 
public void windowDeactivated 
public void windowDeiconified 
public void windowiconified 
public void windowOpened 


(WindowEvent event) {System.exit(0);} 
(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 
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/** 

* button okay action performed 

* Takes the information entered for the operator. Creates a new operator and 

* calls add or change method of the draw class. And sends new operator 

* information there to be added to the list. 

* @param e (ActionEvent) 

**/ 

void btnOK_actionPerformed(ActionEvent e) { 
if(chkResult.isSelected()) 

{ 

display = true; 

} 

else 

{ 

display = false; 

} 

setName(txtName.getText()); 
setRelation((String)cmbRelation 1 .getSelectedltemQ); 
setGroupAtt(txtGroupAtt.getText()); 

if ((txtCondition.getText().equals(""))ll(txtNumber.getText().equals(""))){ 
test.window.message.setMessage 

("You did not enter the condition or count number"); 
test.window.message.show(tme); 

} 

setCondition(txtCondition.getText()); 

setNumber(txtNumber.getText()); 

String [] input = {getRelation(),getGroupAtt(),getCondition(),getNumber()}; 

buildQueryO; 

if (whoIsCalling) 

{ 

test.window.cnvDFQL.change 

(current,indexNum,x,y,getName(),gemumberOfNodes(), 
input,display, getOperatorType(), query); 

) 

else 

{ 

test.window.cnvDFQL.add 

(x,y,getName(),getnumberOfNodes(),input,display, 
getOperatorTypeO, query); 

} 

this.disposeO; 

} 
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* Loads the relations with the tables of the selected database and previously 

* created operators. 

**/ 

void loadSelectO { 

Vector deneme = test.window.currentDatabase.getTableNames(); 
for (int index = 0 ; index < deneme.size(); index-H-) { 
cmbRelationl .addItem((String) deneme.elenientAt(index)); 

} 

for (int xi = 0; xi <test.window.cnvDFQL.numOfOperators;xi-H-){ 
cmbRelationl.addItem(test.window.cnvDFQL.operators[xi].nanie); 

} 

cmbRelation 1 .removeltem(name); 

if (relation== null) 
cmbRelation 1. setSelectedlhdex(O); 
else 

cmbRelation 1. setSelectedltem(relation); 


!** 

* button cancel action performed 

* terminates this frame without creating an operator, decrements the counter 

* @param e (ActionEvent) 

void btnCancel_actionPerformed(ActionEvent e) { 
test.window.Counter[8]—; 
this.disposeO; 

} 


!** 

* This portion of the code produces the SQL query for this operator according 

* to the information entered by user. 

**l 

public void buildQuery(){ 

String checkRelation = isOtherOperator (relation); 
query = "select distinct" + groupAtt; 

if (checkRelation = null) { 

query = query +" from " + relation; 

} 

else { 

query = query + " from " + "(" -i-checkRelation + ")"; 

} 
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if (!condition.equals("")) { 
query = query + " where " + condition; 

} 

query = query + " group by " + groupAtt; 
if (!number.equals("")) 

query = query + " having count (*) " + number; 

} 


* This portion of the code looks for the type of the relations, if they are 

* tables it returns null, otherwise if is another operator, it returns the 

* query of the operator which the current operator related to. 

public String isOtherOperator (String type) { 

String result = null; 

for (int index = 0; index < test.window.DFQLQuery.size(); index++) { 
Operator temp = (Operator) test.window.DFQLQuery.elementAt(index); 
if (type.equalsIgnoreCase(temp.name)) { 
result = temp.query; 
break; 

} 

} 

return result; 

} 

} 

21. Operatorlntersectjava 

package ThesisGUI; 
import j ava. awt.event. *; 
import java.io.*; 
import java.util.*; 
import java.awt.*; 
import javax.swing.*; 
import java.util. Vector; 
import javax.accessibility.*; 
import javax.swing.UIManager; 

!** 

* This frame is used to allow the user to enter the operator information 

* for Intersect operator. It also allwos user to change the information 

* previously entered. 

* AUTHOR: IS & BA 
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public class Operatorlntersect extends JFrame implements WindowListener{ 
/** Type of the operator (constant) **/ 
final static String OPERATOR_TYPE = "Intersect"; 

/** Input node number of the operator (constant) **/ 
final static int NO_INPUT_NODES = 3; 

/** X coordinate of the operator**/ 
private int x; 

/** Y coordinate of the operator**/ 
private int y; 

/** name of the operator**/ 
private String name; 

/** first input node relation**/ 
private String relation 1; 

/** second input node relation**/ 
private String relation2; 

/** common attribute name (intersect point )**/ 
private String attribute; 

/** display information for the operator**/ 
private boolean display = false; 

/** SQL query of the operator**/ 
private String query; 

/** Specify why this frame is called (to create a new one (false) 

* or change the current operator (true)**/ 
private boolean whoIsCalling = false; 

/** The index of the operator in the Operators list **/ 
private int indexNum; 

/** The index of the operator in the DFQLList**/ 
private int current; 

/** name label of the frame**/ 

JLabel IblName = new JLabel(); 

/** first relation label of the frame**/ 

JLabel IblRelationl = new JLabel(); 
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/** second relation label of the frame**/ 

JLabel lblRelation2 = new JLabel(); 

/** common attribute label of the frame**/ 

JLabel Ibl Attribute = new JLabelQ; 

/** text area to enter the name of the operator default diff#**/ 
JTextField txtName = new JTextFieldQ; 

/** text area to enter the name of the intersect attribute**/ 

JTextField txtAttribute = new JTextFieldQ; 

/** check box for display information**/ 

JCheckBox chkResult = new JCheckBoxQ; 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelationl = new JComboBoxQ; 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelation2 = new JComboBoxQ; 

/** Combo box lists the available attributes that can be 

* related to this operator**/ 

JComboBox cmbAttribute = new JComboBoxQ; 

/** Okay button to confirm the info entered**/ 

JButton btnOK = new JButtonQ; 

/** Button cancel to cancel this operation**/ 

JButton btnCancel = new JButtonQ; 

/* CONSTRUCTOR . */ 

/** 

* Default constructor 

* ©parameters X and Y (integer) coordinates of the operator 

public OperatorIntersect(int x, int y) { 
tiy { 

this.x = x; 
this.y = y; 
jblnitQ; 

} 

catch(Exception e) { 
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e.printStackTraceO; 

} 

} 

f** 

* Constructor with all parameters 

* ©parameters @ parameters x, y, callerl, caller2 (integer), 

* name,relationl, relation2, attribute (String), 

* display (boolean) 

public OperatorIntersect(int x, int y, int callerl, int caller2. String name. 
String relation 1, String relation2. String attribute, boolean 
display) 

{ 

this.x = x; 

this.y = y; 

this.current = callerl; 

this.indexNum = caller2; 

this.whoIsCalling = trae; 

this.name = name; 

this.relationl =relationl; 
this.relation2 = relation2; 

this.attribute = attribute; 

this.display = display; 

txtName.setText (name); 
txtAttribute.setText(attribute); 
if (display) { 

chkResult.setSelected(trae); 

} 

else{ 

chkResult.setSelected(false); 

} 

try { 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 
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/** 

* Design constructor 

* ©parameters name 
**! 

public OperatorIntersect(String name) { 
try { 

this.name = name; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 

/* INITIATE METHOD */ 

* The initiation 

* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 

**/ 

private void jblnit() throws Exception { 

IblName.setText ("Name"); 

this.setTitle flntersect"); 

IblRelation 1 .setText ("Relation 1"); 

lblRelation2.setText ("Relation2"); 

IblAttribute.setText ("Attribute"); 

btnOK.setText ("OK"); 

btnCancel.setText fCancel"); 

chkResult. setText ("Display"); 

IblName.setBounds (new Rectangle(4, 2, 93, 18)); 

IblRelation 1 .setBounds (new Rectangle(4,27,93, 18)); 

lblRelation2.setBounds (new Rectangle(4,50,93,18)); 

IblAttribute.setBounds (new Rectangle(4, 73, 93, 18)); 

txtName.setBounds (new Rectangle(80,2,114,17)); 

txtAttribute.setBounds (new Rectangle(80,73,114,17)); 

btnOK.setBounds (new Rectangle(142,100, 54,22)); 

btnCancel.setBounds (new Rectangle(74,100, 60, 23)); 

chkResult.setBounds (new Rectangle(4,100,61,22)); 

cmbRelationl.setBounds (new Rectangle(80,28,114,17)); 

cmbRelation2.setBounds (new Rectangle(79,51, 114, 17)); 

cmbAttribute.setBounds (new Rectangle(80,73,114,17)); 

if (test.window.isDesign()){ 
loadDesignO; 

} 
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else { 

loadSelectO; 

} 

btnOK.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnOK_actionPerformed(e); 

}}); 

btnCaiicel.addActionListener(new java.awt.event.ActioiiListener() { 
public void actionPeiformed(ActionEvent e) { 
btnCancel_actionPerformed(e); 

}}); 

cmbRelationl.setBorder (null); 

cmbRelation2.setBorder (null); 

chkResult.setBorderPainted (true); 

chkResult.setFont (new java.awt.Font("Dialog", 0,11)); 
btnCancel.setFont (new java.awt.Font("Dialog", 0, 11)); 
btnOK.setFont (new java.awt.Font("Dialog", 0,11)); 

btnOK.setBorder (BorderFactory.createRaisedBevelBorderO); 

chkResult.setBorder (BorderFactory.createRaisedBevelBorderO); 

btnCancel.setBorder (BorderFactory.createRaisedBevelBorderO); 

this.getContentPane().setLayout(null); 
this.getContentPane().add(lblName, null); 
this.getContentPane().add(txtName, null); 
this.getContentPane().add(lblRelation 1, null); 
this.getContentPane().add(cmbRelationl, null); 
this.getContentPane().add(cmbRelation2, null); 
this.getContentPane().add(lblRelation2, null); 
this.getContentPaneO .add(chkResult, null); 
this.getContentPane().add(btnOK, null); 
this.getContentPane().add(btnCancel, null); 
this.getContentPane().add(lblAttribute,null); 
if (test.window.isDesign()){ 
this.getContentPane().add(cmbAttribute, null); 

} 

else { 

this.getContentPane().add(txtAttribute, null); 

} 

this.setBounds(100,100,210,170); 
this.show(true);} 


239 




Set Methods 



*/ 


* Sets the first relation of the operator 

* ©parameter relation 1 (String) 


public void setRelationl (String relation 1){ 
this.relationl =relationl; 

} 


* Sets the second relation of the operator 

* ©parameter relation2 (String) 

public void setRelation2 (String relation2){ 
this.relation2 = relation2; 

} 


/** 

* Sets the name of the operator 

* ©parameter name (String) 

public void setName (String name){ 
this.name = name; 

} 


* Sets the intersect attribute 

* ©parameter attribute (String) 

public void setAttribute (String attribute) { 
this.attribute = attribute; 

} 


/* Get Methods */ 

* Gets the number of the input nodes of the operator 

**/ 

public int getnumberOfNodes(){ 
return this.NO_INPUT_NODES; 

} 


* Gets the type of the operator 


public String getOperatorType(){ 
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return this.OPERATOR_TYPE; 

} 


* Gets the first relationof the operator 

public String getRelationl (){ 
return this.relationl; 

} 


* Gets the second relation of the operator 
**! 

public String getRelationl (){ 
return this.relationl; 

} 


/** 

* Gets the name of the operator 

public String getName (){ 
return this.name; 

} 

/** 

* Gets the intersect attribute of the operator 
**! 

public String getAttribute (){ 
return this.attribute; 

} 


/* 


!** 


WINDOW ACTIVATIONS 


*/ 


* The window listener methods 

* @param event (WindowEvent) 
**! 

public void windowClosing 
public void window Activated 
public void windowClosed 
public void windowDeactivated 
public void windowDeiconified 
public void windowiconified 
public void windowOpened 


(WindowEvent event) {System.exit(0);} 
(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event){} 

(WindowEvent event) {} 

(WindowEvent event){} 
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* button okay action performed 

* Takes the information entered for the operator. Creates a new operator and 

* calls add or change method of the draw class. And sends new operator 

* information there to be added to the list. 

* @param e (ActionEvent) 

void btnOK_actionPerformed(ActionEvent e) { 
if(chkResult.isSelected()) { 
display = true; 

} 

else{ 

display = false; 

} 

setName(txtName.getText()); 
setRelationl((String)cmbRelationl.getSelectedItem()); 
setRelation2((String)cmbRelation2.getSelectedItem()); 
if (test.window.isDesign()){ 
setAttribute((String)cmbAttribute.getSelectedItem()); 

} 

else{ 

setAttribute(txtAttribute.getText()); 
if (txtAttribute.getText().equals("")) { 

test.window.message.setMessageC'You did not enter the attribute list"); 
test.window.message.show(true); 

} 

} 

String [] input = {getRelationl(),getRelation2(),getAttribute(),’’none","none"}; 
buildQueryO; 

if (test.window.isDesign()){ 
test.window.designQueries.addElement(query); 

} 

else { 

if (whoIsCalling){ 
test.window.cnvDFQL.change 

(current,indexNum,x,y,getName(),getnumberOfNodes(), 
input,display, getOperatorType(), query); 

} 

else { 

test.window.cnvDFQL.add 

(x,y,getName(),getnumberOfNodes(),input,display, 
getOperatorTypeO, query); 

}} 

this.disposeO; 

} 
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!** 

* Loads the relations with the tables of the selected database and previously 

* created operators. 

**! 

void loadSelectQ { 
if(! whoIsCalling) { 

txtName.setText("Intersect"+test.window.Counter[ 12]++); 

} 

Vector deneme = test.window.currentDatabase.getTableNames(); 
for (int index = 0 ; index < deneme.size(); index-H-) { 
cmbRelationl .addItem((String) denenie.elementAt(index)); 
cmbRelation2.addItem((String) deneme.elementAt(index)); 

} 

for (int xi = 0; xi <test.window.cnvDFQL.nuniOfOperators;xi++){ 
cmbRelationl.addItem(test.window.cnvDFQL.operators[xi].name); 
cmbRelation2.addItem(test.window.cnvDFQL.operators[xi].name); 

} 

cmbRelation 1 .removeltem(name); 
cmbRelation2.removeItem(name); 

if (relation 1= null) 
cmbRelation 1 .setSelectedIndex(0); 
else 

cmbRelation 1. setSelectedItem(relation 1); 
if (relation2= null) 
cmbRelation2.setSelectedIndex(0); 
else 

cmbRelation2.setSelectedItem(relation2); 

txtAttribute.setText(attribute); 


!** 

* button cancel action performed 

* terminates this frame without creating an operator, decrements the counter 

* @param e (ActionEvent) 

**/ 

void btnCancel_actionPerforraed(ActionEvent e) { 
test, window .Counter[ 12]--; 
this.disposeO; 

} 
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* This portion of the code produces the SQL query for this operator according 

* to the information entered by user. 

**! 

public void buildQuery(){ 

String checkRelation = isOtherOperator (relationl); 
if (checkRelation = null) { 

query = "select distinct" + attribute +" from" + relationl +" S where S." 

+ attribute + " in"; 

} 

else { 

query = "select distinct" + attribute +" from" +"(" 

+checkRelation +") S where S." + attribute + " in"; 

} 

checkRelation = isOtherOperator(relation2); 
if (checkRelation == null) { 

query = query + " (select" + attribute +" from " + relation2 + ")"; 

} 

else { 

query = query + "(select " + attribute + " from " + "(" +checkRelation + "))"; 

} 

* This portion of the code looks for the type of the relations, if they are 

* tables it returns null, otherwise if is another operator, it returns the 

* query of the operator which the current operator related to. 

public String isOtherOperator (String type) { 

String result = null; 

for (int index = 0; index < test.window.DFQLQuery.size(); index-H-) { 
Operator temp = (Operator) test.window.DFQLQuery.elementAt(index); 
if (type.equalsIgnoreCase(temp.name)) { 
result = temp.query; 
break; 

} 

} 

return result; 

} 
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* This function is used to fill the combo boxes with the selection alternatives 

* if this operator is created as a part of a user defined operator then the 

* relation and condition combo boxes are filled with user defined operator 

* input items. 


private void loadDesign(){ 
txtName.setText(name); 

for (int index = 0; index < test.window.designRelation.sizeQ; index-H-) { 
cmbRelation 1 .addItem((String) test. window.designRelation.elementAt 

(index)); 

cmbRelation2.addItem((String) test.window.designRelation.elementAt 

(index)); 


} 


for (int opindex = 0 ; opindex < test.window.designOps.size(); opIndex++) { 
if (!name.equalsIgnoreCase((String) test.window.designOps.elementAt 

(opindex))) { 

cmbRelation 1 .addItem((String) test.window.designOps.elementAt 

(opindex)); 

cmbRelation2.addItem((String) test.window.designOps.elementAt 

(opindex)); 

} 

} 


for (int attindex = 0; attindex < test.window.designAttribute.size(); 
attIndex-H-){ 

cmbAttribute.addItem((String) test.window.designAttribute.elementAt 
(attindex)); 

} 

} 

} 


22. OperatorJoin.Java 


package ThesisGUI; 

import j ava.awt.event. *; 
import java.io.*; 
import java.util.*; 
import j ava.awt. *; 
import j avax. swing. *; 
import java.util. Vector; 
import javax.accessibility.*; 
import javax.swing.UIManager; 
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* This frame is used to allow the user to enter the operator information 

* for join operator. It also allwos user to change the information 

* previously entered. 

* AUTHOR : IS & BA 

**! 

public class OperatorJoin extends JFrame implements WindowListener{ 

/** Type of the operator (constant) **/ 
final static String OPERATOR_TYPE = "Join"; 

/** Input node number of the operator (constant) **/ 
final static int NO_INPUT_NODES = 3; 

/** X coordinate of the operator**/ 
private int x; 

/** Y coordinate of the operator**/ 
private int y; 

/** name of the operator**/ 
private String name; 

/** first input node relation**/ 
private String relation 1; 

/** second input node relation**/ 
private String relation2; 


/** Condition**/ 
private String condition; 

/** display information for the operator**/ 
private boolean display = false; 

/** SQL query of the operator**/ 
private String query; 

/** Specify why this frame is called (to create a new one (false) 
* or change the current operator (true)**/ 
private boolean whoIsCalling = false; 

/** The index of the operator in the Operators list **/ 
private int indexNum; 
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/** The index of the operator in the DFQLList**/ 
private int current; 

/** The list of the possible index of the operator in the DFQLList**/ 
private String [] operators = "<="}; 

/** name label of the frame**/ 

JLabel IblName = new JLabelQ; 

/** first relation label of the frame**/ 

JLabel IblRelationl = new JLabelQ; 

/** second relation label of the frame**/ 

JLabel lblRelation2 = new JLabelQ; 

/** text area to enter the name of the operator default diff#**/ 
JTextField txtName = new JTextFieldQ; 

/** Okay button to confirm the info entered**/ 

JButton btnOK = new JButtonQ; . 

/** check box for display information**/ 

JCheckBox chkResult = new JCheckBoxQ; 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelationl = new JComboBoxQ; 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelationl = new JComboBoxQ; 

/** join attribute list label of the frame**/ 

JLabel IblCondition = new JLabelQ; 

/** text area to enter the condition for the operator**/ 

JTextField txtCondition = new JTextFieldQ; 

/** Combo box lists the available conditions that can be 

* related to this operator**/ 

JComboBox cmbDesignCondition = new JComboBoxQ; 

/** Button cancel to cancel this operation**/ 

JButton bmCancel = new JButtonQ; 
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/** Combo box lists the available operators for join operation **/ 
JComboBox cmbOperator = new JComboBoxQ; 

/* CONSTRUCTOR */ 

!** 

* Default constructor 

* ©parameters X and Y (integer) coordinates of the operator 

public OperatorJoin(int x, int y) { 
try { 

this.x = x; 
this.y = y; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 


/** 

* Constructor with all parameters 

* ©parameters © parameters x, y, caller 1, caller! (integer), 

* name,relationl, relation!, condition (String), 

* display (boolean) 

public OperatorJoin(int x, int y, int caller 1, int caller!. String name. 
String relation 1, String relation!. String condition, 
boolean display)! 


this.x 

= x; 

this.y 

= y; 

this.current 

= callerl; 

this.indexNum 

= caller!; 

this.whoIsCalling 

= true; 

this.name 

= name; 

this.relationl 

= relation 1; 

this.relation! 

= relation!; 

int length 

= condition.lengthO; 

StringBuffer sub 

= new StringBuffer(condition); 

condition 

= sub.substring(0,length-!); 

this.condition 

= condition; 

this.display 

= display; 

txtName.setText 

(name); 

txtCondition.setText (condition); 

if (display)! 


chkResult.setSelected(true); 
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} 

else{ 

chkResult.setSelected(false); 

} 

try { 
jblnitO; 

) 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 


* Design constructor 

* ©parameters name 

public OperatorJoin(String name) { 
try { 

this.name = name; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 


/* INITIATE METHOD */ 


* The initiation 

* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 


private void jblnitO throws 

IblName.setText 

this.setTitle 

IblRelationl .setText 

IblRel ation2. setT ext 

IblCondition.setText 

btnOK.setText 

btnCancel.setText 

chkResultsetText 


Exception { 

("Name"); 

("Join"); 

("Relation 1"); 

("Relation2"); 

("Condition"); 

("OK"); 

("Cancel"); 

("Display"); 


btnCancel.setBounds 

cmbOperator.setBounds 

IblName.setBounds 


(new Rectangle(78,93, 60,23)); 
(new Rectangle(150,68,44,17)); 
(new Rectangle(4, 2,93,18)); 
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IblRelation 1 .setBounds 

lblRelation2.setBounds 

IblCondition.setBounds 

txtName.setBounds 

txtCondition.setBounds 

cmbDesignCondition.setBounds 

btnOK.setBounds 

chkResult.setBounds 

cmbRelationl .setBounds 

cmbRelationl.setBounds 


(new Rectangle(4,22,93, 18)); 
(new Rectangle(5,45,93,18)); 
(new Rectangle(4, 67,93, 18)); 
(new Rectangle(80,2,114,17)); 
(new Rectangle(80,68, 59,17)); 
(new Rectangle(80, 68,59,17)); 
(new Rectangle(147,93,53,22)); 
(new Rectangle(4, 93, 64, 22)); 
(new Rectangle(80,23,114,17)); 
(new Rectangle(80,46,114,17)); 


for (int ix = 0 ; ix < 5; ix-H-){ 
cmbOperator.addItem(operators[ix]); 

} 


if (test.window.isDesign()){ 
loadDesignO; 

} 

else { 

loadSelectO; 

} 

btnOK.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnOK_actionPeiformed(e); 

}}); 

btnCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnCancel_actionPerformed(e); 

}}); 

cmbRelation 1 .setBorder (null); 

chkResult.setBorderPainted (trae); 

cmbRelation2.setBorder (null); 

chkResult.setFont (new java.awt.Font("Dialog", 0,11)); 
btnOK-setFont (new java.awt.Font("Dialog", 0, 11)); 
btnCancel.setFont (new java.awt.Font("Dialog", 0,11)); 

btnCancel.setBorder (BorderFactory.createRaisedBevelBorder()) 

chkResult.setBorder (BorderFactory.createRaisedBevelBorder()): 

btnOK.setBorder (BorderFactoiy.createRaisedBevelBorderO); 

this.getContentPane().setLayout(null); 
this.getContentPane0.add(lblName, null); 
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this.getContentPaiie().add(txtNaine, null); 
this.getContentPane().add(lblRelation 1, null); 
this.getContentPane().add(cmbRelation2, null); 
this.getContentPane().add(lblRelation2, null); 
if (test.window.isDesign()){ 
this.getContentPane().add(cmbDesignCondition, null); 

} 

else{ 

this.getContentPane().add(txtCondition, null); 

} 

this.getContentPane().add(lblCondition, null); 
this.getContentPane().add(chkResult, null); 
this.getContentPane().add(btnCancel, null); 
this.getContentPane().add(btnOK, null); 
this.getContentPane().add(cnibRelationl, null); 
this.getContentPane().add(cmbOperator, null); 

this.setBounds( 100,100,210,150); 
this.show(trae); 

} 

/* Set Methods */ 

/** 

* Sets the first relation of the operator 

* ©parameter relation 1 (String) 

**/ 

public void setRelationl (String relation 1){ 
this.relationl = relation 1; 

} 


/** 

* Sets the second relation of the operator 

* ©parameter relation2 (String) 

public void setRelation2 (String relation2){ 
this.relation2 = relation2; 

} 


/** 

* Sets the name of the operator 

* ©parameter name (String) 

**/ 

public void setName (String name){ 
this.name = name; 

} 
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* Sets the condition of the operator 

* ©parameter condition (String) 

public void setCondition (String condition) { 
this.condition = condition; 

} 


/* Get Methods */ 

* Gets the number of the input nodes of the operator 
**/ 

public int getnumberOfNodes(){ 
return this.NO_INPUT_NODES; 

} 


/** 

* Gets the type of the operator 

public String getOperatorType(){ 
return this.OPERATOR_TYPE; 

} 


* Gets the first relationof the operator 
**/ 

public String getRelationl (){ 
return this.relationl; 

} 


* Gets the second relation of the operator 
**/ 

public String getRelation2 (){ 
return this.relation2; 

} 


/** 

* Gets the name of the operator 
**! 

public String getName (){ 
return this.name; 

} 
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/** 

* Gets the condition of the operator 

**/ 

public String getCondition (){ 
return this.condition; 

} 


/* WINDOW ACTIVATIONS */ 


* The window listener methods 

* @param event (WindowEvent) 

**f 

public void windowClosing 
public void window Activated 
public void windowClosed 
public void windowDeactivated 
public void windowDeiconified 
public void windowiconified 
public void windowOpened 


(WindowEvent event) {System.exit(0);} 
(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 


/** 

* button okay action performed 

* Takes the information entered for the operator. Creates a new operator and 

* calls add or change method of the draw class. And sends new operator 

* information there to be added to the list. 

* @param e (ActionEvent) 

void btnOK_actionPerformed(ActionEvent e) { 
if(chkResult.isSelected()) { 
display = true; 

} 

else{ 

display = false; 

} 

setName(txtName.getText()); 

setRelation 1 ((String)cmbRelation 1 .getSelectedItem()); 
setRelation2((String)cmbRelation2.getSelectedItem()); 


if (test.window.isDesign()){ 

setCondition((String)cmbDesignCondition.getSelectedItem()+" 

"+cmbOperator.getSelectedItem()); 

} 

else { 

if (txtCondition.getText().equals("")){ 
test.window.message.setMessage 

("You did not enter the join condition for the relations"); 
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test.window.message.show(true); 

} 

else { 

String cond = txtCondition.getText()+" "+cmbOperator.getSelectedItem(); 
setCondition(cond); 

} 

} 

String [] input = {getRelationl(),getRelation2(),getCondition(),"none"}; 
buildQueryO; 

if (test.window.isDesign()){ 

System.out.println(query); 

test.window.designQueries.addElement(query); 

} 

else { 

if (whoIsCalling){ 
test, window .cnvDFQL.change 

(current,indexNum,x,y,getName(),getnumberOfNodes(), 
input,display, getOperatorType(), query); 

} 

else { 

test, window .cnvDFQL.add 

(x,y,getName(),getnumberOfNodes(),input,display, 
getOperatorTypeO, query); 

} 

} 

this.disposeO; 

} 


* Loads the relations with the tables of the selected database and previously 

* created operators. 

void loadSelectO { 

Vector deneme = test.window.currentDatabase.getTableNames(); 
if(! whoIsCalling) { 

txtName.setText("Join"+test.window.Counter[2]-H-); 

} 

for (int index = 0 ; index < deneme.size(); index-H-) { 
cmbRelationl .addItem((String) deneme.elementAt(index)); 
cmbRelation2.addItem((String) deneme.elementAt(index)); 

} 
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for (int xi = 0; xi <test.window.cnvDFQL.numOfOperators;xi-H-) { 
cmbRelation 1 .addItem(test.wmdow.cnvDFQL.operators [xi] .name); 
cmbRelation2.addItem(test.window.cnvDFQL.operators[xi].name); 

} 

cmbRelation 1 .removeItem(name); 
cmbRelation2.removeItem(name); 

if (relation 1== null) 
cmbRelation 1 .setSelectedlndex(O); 
else 

cmbRelation 1. setSelectedItem(relation 1); 
if (relation2== null) 
cmbRelation2.setSelectedIndex(0); 
else 

cmbRelation2.setSelectedItem(relation2); 


* button cancel action performed 

* terminates this frame without creating an operator, decrements the counter 

* @param e (ActionEvent) 

**/ 

void btnCancel_actionPerformed(ActionEvent e) { 
test.window.Counter[2]--; 
this.disposeO; 

} 


* This portion of the code produces the SQL query for this operator according 

* to the information entered by user. 

**/ 


public void buildQuery (){ 

String checkRelation = isOtherOperator (relation 1); 
if (checkRelation == null) { 

query = "select distinct * from" + relation 1+" 
j"+test.window.Counter[2]*2+","; 

} 

else { 

query = "select distinct * from " + "(" +checkRelation + ") 
j "+test.window.Counter[2] *2+","; 

} 

checkRelation = isOtherC)perator(relation2); 


if (checkRelation == null) { 

query = query + relation2 +" j"+test.window.Counter[2]*2 +1; 
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} 

else { 

query = query + "(" +checkRelation + ") j"+test.window.Counter[2]*2 +1; 

} 

if (!(condition.equals(""))) { 

StringBuffer sub = new StringBuffer (condition); 

int length = condition.length(); 

String cond = sub.substring(0,length-2); 

String oprt = sub.substring(length-2); 

query = query +" where j"+test.window.Counter[2]*2+"." + cond +"" + oprt 
+ " j"+test.window.Counter[2]*2+l+"." + cond; 

} 

} 


* This portion of the code looks for the type of the relations, if they are 

* tables it returns null, otherwise if is another operator, it returns the 

* query of the operator which the current operator related to. 

public String isOtherOperator (String type) { 

String result = null; 

for (int index = 0; index < test.window.DFQLQuery.sizeQ; index++) { 
Operator temp = (Operator) test.window.DFQLQueiy.elementAt(index); 
if (t)q)e.equalsIgnoreCase(temp.name)) { 
result = temp.query; 
break; 

} 

} 

return result; 

} 


* This function is used to fill the combo boxes with the selection alternatives 

* if this operator is created as a part of a user defined operator then the 

* relation and condition combo boxes are filled with user defined operator 

* input items. 

**/ 

private void loadDesign(){ 
txtName.setText(name); 

for (int index = 0 ; index < test.window.designRelation.size(); index-H-) { 
cmbRelation 1 .addItem((String) test.window.designRelation.elementAt 

(index)); 

cmbRelation2.addItem((String) test.window.designRelation.elementAt 
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(index)); 

} 

for (int opindex = 0; opLidex < test.window.designOps.size(); opIndex-H-) { 
if (!name.equalsIgnoreCase((String) test.window.designOps.elementAt 

(opindex))) { 

cmbRelation 1 .addltem( (String) test.window.designOps.elementAt 

(opindex)); 

cmbReIation2.addItem((String) test.window.designOps.elenientAt 

(opindex)); 

} 

} ■ 

for (int conindex = 0; conindex < test.window.designCondition.size(); 
conIndex++){ 

cmbDesignCondition.addItem 

((String) test.window.designCondition.elementAt(conIndex)); 

} 

} 

} 

23. OperatorProjectJava 

package ThesisGUI; 

import java.awt.event.*; 
import javaJo.*; 
import java.util.*; 
import java.awt.*; 
import javax.swing.*; 
import java.util. Vector; 
iinport javax.accessibility.*; 
import javax.swing.UIManager; 

/** 

* This frame is used to allow the user to enter the operator information 

* for project operator. It also allwos user to change the information 

* previously entered. 

* AUTHOR : IS & BA 
**/ 

public class OperatorProject extends JFrame implements WindowListener{ 

/** Type of the operator (constant) **/ 

final static String OPERATOR_TYPE = "Project"; 
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/** Input node number of the operator (constant) **! 
final static int NO_INPlJT_NODES = 2; 

/** X coordinate of the operator**/ 
private int x; 

/** Y coordinate of the operator**/ 
private int y; 

/** name of the operator**/ 
private String name; 

/** input node relation**/ 
private String relation; 

/** input node attribute list**/ 
private String attributeList; 

/** display information for the operator**/ 
private boolean display = false; 

/** SQL query of the operator**/ 
private String query; 

/** Specify why this frame is called (to create a new one (false) 
* or change the current operator (true)**/ 
private boolean whoIsCalling = false; 

/** The index of the operator in the Operators list **/ 
private int indexNum; 

/** The index of the operator in the DFQLList**/ 
private int current; 

/** name label of the frame**/ 

JLabel IblName = new JLabel(); 

/** first relation label of the frame**/ 

JLabel IblRelation = new JLabel(); 

/** second relation label of the frame**/ 

JLabel IblAttributeList = new JLabel(); 

/** text area to enter the name of the operator default diff#**/ 
JTextField txtName = new JTextField(); 
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/** Okay button to confirm the info entered**/ 

JButton btnOK = new JButtonO; 

/** check box for display information**/ 

JCheckBox chkResult = new JCheckBoxQ; 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelation = new JComboBox(); 

/** Allows user to enter the attribute list**/ 

JTextField txtAttributeList = new JTextFieldQ; 

/** Combo box lists the available attributes that can be 

* related to this operator**/ 

JComboBox cmbAttribute = new JComboBoxQ; 

/** Button cancel to cancel this operation**/ 

JButton btnCancel = new JButton(); 

/* CONSTRUCTOR */ 

/** 

* Default constructor 

* ©parameters X and Y (integer) coordinates of the operator 
**! 

public OperatorProject(int x, int y) { 
try { 

this.x = x; 
this.y = y; 

this.whoIsCalling = false; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 

!** 

* Constructor with all parameters 

* ©parameters © parameters x, y, caller 1, caller2 (integer), 

* name,relation, attList (String), 

* display (boolean) 

**! 

public OperatorProject(int x, int y, int caller 1, int caller2. String name. 
String relation. String attList, boolean display)! 
this.x = x; 
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this.y 

this.current 

this.indexNum 

this.whoIsCalling 

this.name 

this.relation 

this.attributeList 

this.display 


= y; 

= callerl; 
= caller2; 
= tme; 

= name; 

= relation; 
= attList; 
= display; 


txtName.setText (name); 

txtAttributeList.setText (attributeList); 


if (display)! 

chkResult.setSelected(true); 

} 

else{ 

chkResult.setSelected(false); 

} 

try { 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 


* Design constructor 

* ©parameters name 
**! 

public C)peratorProject(String name) { 
try { 

this.name = name; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 
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I* INITIATE METHOD */ 

!** 

* The initiation 

* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 

**! 

private void jbLiit() throws Exception { 

IblName.setText ("Name"); 

this.setTitle ("Project"); 

IblRelation.setText ("Relation"); 

IblAttributeList-setText ("Att. List"); 

btnOK.setText ("OK"); 

chkResult.setText ("Display"); 

btnCancel.setText ("Cancel"); 

IblName.setBounds (new Rectangle(4,2, 93,18)); 

IblRelation.setBounds (new Rectangle(4,27, 93, 18)); 

IblAttributeList.setBounds (new Rectangle(3,49,93, 18)); 
txtName.setBounds (new Rectangle(71,3,114,17)); 

txtAttributeList.setBounds (new Rectangle(70,50,114,17)); 

cmbAttribute.setBounds (new Rectangle(70, 50, 114, 17)); 

btnOK-setBounds (new Rectangle(136, 73, 51,23)); 

cmbRelation.setBounds (new Rectangle(71,28,114, 17)); 

btnCancel.setBounds (new Rectangle(70, 73, 60, 23)); 

chkResult.setBounds (new Rectangle(2,73,62,23)); 

if (test.window.isDesign()){ 
loadDesignO; 

} 

else { 

loadSelectO; 

} 

btnOK.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnOK_actionPerformed(e); 

}}); 

btnCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnCancel_actionPerformed(e); 

}}); 


ch kR esult.setBorderPainted 

cmbRelation.setBorder 


(true); 

(null); 



chkResult-setFont (newjava.awt.Font("Dialog", 0,11)); 
btnCancel.setFont (new java.awt.Font("Dialog", 0,11)); 
btnOK.setFont (new java.awt.Font("Dialog", 0,11)); 

btnOK.setBorder (BorderFactory.createRaisedBevelBorderO); 

btnCancel.setBorder (BorderFactory.createRaisedBevelBorder()); 

chkResult.setBorder (B6rderFactory.createRaisedBevelBorder()); 

this.getContentPane().setLayout(null); 
this.getContentPane().add(lblName, null); 
this.getContentPane().add(lblRelation, null); 
this.getContentPane().add(cmbRelation, null); 
this.getContentPane().add(txtName, null); 
this.getContentPane().add(btnCancel, null); 
this.getContentPane().add(lblAttributeList, null); 
if (test.window.isDesign()){ 
this.getContentPane().add(cmbAttribute, null); 

} 

else { 

this.getContentPane().add(txtAttributeList, null); 

} 

this.getContentPane().add(chkResult, null); 
this.getContentPane().add(btnOK, null); 

this.setBounds(100,100,200,130); 
this.show(trae); 

} 

/* Set Methods */ 

/** 

* Sets the relation of the operator 

* ©parameter relation (String) 

**f 

public void setRelation (String relation) { 
this.relation = relation; 

} 


* Sets the attribute list of the operator 

* ©parameter attributeList (String) 

public void setAttList (String attributeList) { 
this.attributeList = attributeList; 

} 
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/** 

* Sets the name of the operator 

* ©parameter name (String) 

**/ 

public void setName (String name){ 
this.name = name; 

} 


/* Get Methods */ 

/** 

* Gets the input node number of the operator 

**! 

public int getnumberOfNodes(){ 
return this.NO_INPUT_NODES; 

} 


* Gets the type of the operator 

**! 

public String getOperatorT 5 ^e(){ 
return this.OPERATOR_TYPE; 

} 


* Gets the relation of the operator 

**! 

public String getRelation (){ 
return this.relation; 

} 


* Gets the attribute list of the operator 
**! 

public String getAttList (){ 
return this.attributeList; 

} 


/** 

* Gets the name of the operator 
**! 

public String getName (){ 
return this.name; 

} 
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/* WINDOW ACTIVATIONS */ 

!** 

* The window listener methods 

* @param event (WindowEvent) 

**l 

public void windowClosing (WindowEvent event) {System.exit(O);} 

public void window Activated (WindowEvent event) {} 

public void windowClosed (WindowEvent event) {} 

public void windowDeactivated (WindowEvent event) {} 

public void windowDeiconified (WindowEvent event) {} 

public void windowiconified (WindowEvent event) {} 

public void windowOpened (WindowEvent event) {} 


* button okay action performed 

* Takes the information entered for the operator. Creates a new operator and 

* calls add or change method of the draw class. And sends new operator 

* information there to be added to the list. 

* @param e (ActionEvent) 

void btnOK_actionPerformed(ActionEvent e) { 
if (chkResult.isSelected()){ 
display = true; 

} 

else{ 

display = false; 

1 

setName (txtName.getText()); 
setRelation((String)cmbRelation.getSelectedItem()); 
if (test.window.isDesign()){ 
setAttList((String)cmbAttribute.getSelectedItem()); 

} 

else{ 

setAttList(txtAttributeList.getText()); 
if (txtAttributeList.getText().equals("")) { 

test.window.message.setMessageC You did not enter the attribute list"); 
test.window.message.show(trae); 

} 

} 

String [] input = {getRelation(),getAttList(),"none","none"}; 
buildQueryO; 

if (test.window.isDesign()){ 
test.window.designQueries.addElement(query); 

} 

else { 
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if (whoIsCalling) { 
test.window.cnvDFQL.change 

(current,mdexNum,x,y,getName(),getnumberOfNodes(), 
input,display, getOperatorType(),query); 

} 

else { 

test.window.cnvDFQL.add 

(x,y,getName(),getnumberOfNodes(),input,display, 
getOperatorTypeQ, query); 

} 

} 

this.disposeO; 

} 


* Loads the relations with the tables of the selected database and previously 

* created operators. 

**f 

void loadSelectO { 

Vector deneme = test.window.currentDatabase.getTableNamesO; 
if(! whoIsCalling) { 

txtName.setText("Project"+test.window.Counter[ 1 ]++); 

} 

for (int index = 0; index < deneme.size(); index-H-) { 
cmbRelation.addItem((String) deneme.elementAt(index)); 

} 

for (int xi = 0; xi ><test.window.cnvDFQL.numOfOperators;xi-H-) 
cmbRelation.addItem(test.window.cnvDFQL.operators[xi].name); 

cmbRelation.removelteni(name); 
if (relation = null) 
cmbRelation.setSelectedlndex(O); 
else 

cmbRelation.setSelectedltem(relation); 


!** 

* button cancel action performed 

* terminates this frame without creating an operator, decrements the counter 

* @param e (ActionEvent) 

**/ 

void btnCancel_actionPerformed(ActionEvent e) { 
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test.window.Counter[ 1 ]—; 
this.disposeO; 


* This portion of the code produces the SQL query for this operator according 

* to the information entered by user. 

public void buildQuery (){ 

String checkRelation = isOtherOperator (relation); 
if (!attributeList.equals("")){ 
query = "select distinct" + attributeList; 

} 

else { 

query = "select distinct 

} 

if (checkRelation == null) { 
query = query + " from " + relation; 

} 

else { 

query = query + " from " + "(" +checkRelation + ")"; 

} 


* This portion of the code looks for the type of the relations, if they are 

* tables it returns null, otherwise if is another operator, it returns the 

* query of the operator which the current operator related to. 

**! 

public String isOtherOperator (String type) { 

String result = null; 

for (int index = 0; index < test.window.DFQLQuery.size(); index-H-) { 
Operator temp = (Operator) test.window.DFQLQuery.elementAt(index); 
if (type.equalsIgnoreCase(temp.name)) { 
result = temp.query; 
break; 

} 

} 

return result; 

} 


* This function is used to fill the combo boxes with the selection alternatives 

* if this operator is created as a part of a user defined operator then the 

* relation and condition combo boxes are filled with user defined operator 
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* input items. 
**/ 


private void loadDesign(){ 
txtName.setText(name); 

for (int index = 0; index < test.window.designRelation.size(); index-H-) { 
cmbRelation.addItem((String) test.window.designRelation.elementAt 
(index)); 


} 


for (int opiidex = 0; opindex < test.window.designOps.size(); opIndex-f+) { 
if (!name.equalsIgnoreCase((String) test.window.designOps.elementA.t 

(opindex))) 

cmbRelation.addItem((String) test.window.designC)ps.elementAt 

(opindex)); 


} 


for (int attindex = 0; attindex < test.window.designAttribute.size(); 
attIndex-H-){ 

cmbAttribute.addItem((String) test.window.designAttribute.elementAt 

(attindex)); 

} 

} 

} 


OperatorSelectJava 


package ThesisGUI; 

import java.awt.event.*; 
import java.io.*; 
import java.util.*; 
import java.awt.*; 
import j avax.swing. *; 
import java.util. Vector; 
import j avax.accessibility. *; 
import j avax.swing.UIManager; 

!** 

* This frame is used to allow the user to enter the operator information 

* for select operator. It also allwos user to change the information 

* previously entered. 

* AUTHOR: IS & BA 
**/ 

public class OperatorSelect extends JFrame implements WindowListenerf 
/** Type of the operator (constant) **/ 
final static String OPERATOR.TYPE = "Select"; 
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/** Input node number of the operator (constant) **/ 
final static int NO_INPUT_NODES = 2; 

/** X coordinate of the operator**/ 
private int x; 

/** Y coordinate of the operator**/ 
private int y; 

/** name of the operator**/ 
private String name; 

/** input node relation**/ 
private String relation; 

/** input node attribute list**/ 
private String condition; 

/** display information for the operator**/ 
private boolean display = false; 

/** SQL query of the operator**/ 
private String query; 

/** Specify why this frame is called (to create a new one (false) 
* or change the current operator (true)**/ 
private boolean whoIsCalling = false; 

/** The index of the operator in the Operators list **/ 
private int indexNum; 

/** The index of the operator in the DFQLList**/ 
private int current; 

/** name label of the frame**/ 

JLabel IblName = new JLabel(); 

/** first relation label of the frame**/ 

JLabel IblRelation = new JLabel(); 

/** second relation label of the frame**/ 

JLabel IblCondition = new JLabel(); 

/** text area to enter the name of the operator default diff#**/ 
JTextField txtName = new JTextField(); 
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/** Okay button to confirm the info entered**/ 

JButton btnOK = new JButton(); 

/** check box for display information**/ 

JCheckBox chkResult = new JCheckBoxQ; 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelation = new JComboBox(); 

/** Combo box lists the available conditions that can be 

* related to this operator**/ 

JComboBox cmbDesignCondition = new JComboBox(); 

/** Allows user to enter the attribute list**/ 

JTextField txtCondition = new JTextField(); 

/** Button cancel to cancel this operation**/ 

JButton btnCancel = new JButton(); 

/* CONSTRUCTOR */ 

/** 

* Default constructor 

* ©parameters X and Y (integer) coordinates of the operator 
**! 

public OperatorSelect(int x, int y) { 
try { 

this.x = x; 
this.y = y; 

. this.whoIsCalling = false; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 


* Constructor with all parameters 

* ©parameters © parameters x, y, callerl, caller2 (integer), 

* name,relation, condition (String), 

* display (boolean) 

public OperatorSelect(int x, int y, int callerl, int caller2. String name. 
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String relation. String condition, boolean display)! 
this.x = x; 

this.y = y; 

this.current = caller 1; 

this.indexNum = caller2; 

this.whoIsCalling = true; 

this.name = name; 

this.relation = relation; 

this.condition = condition; 

this.display = display; 

txtName.setText (name); 

txtCondition.setText (condition); 

if (display)! 

chkResult.setSelected(true); 

} 

else! 

chkResult.setSelected(false); 

} 

try ! 
jblnitO; 

} 

catch(Exception e) ! 
e.printStackTraceO; 

} 

} 


* Design constructor 

* ©parameters name 

**/ 

public OperatorSelect(String name)! 
try ! 

this.name = name; 
jblnitO; 

) 

catch(Exception e)! 
e.printStackTraceO 5 

} 

} 

/* INITIATE METHOD */ 

/** 

* The initiation 
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* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 


private void jbhiit() throws Exception { 
IblName.setText 
this.setXitle 
IblRelation.setText 
IblCondition.setText 
btnOK.setText 
btnCancel.setText 
chkResult. setText 


("Name"); 

("Select"); 

("Relation"); 

("Condition"); 

("OK"); 

("Cancel"); 

("Display"); 


IblName.setBounds 

IblRelation.setBounds 

IblCondition.setBounds 

txtName.setBounds 

txtCondition.setBounds 

cmbDesignCondition.setBounds 

btnOK.setBounds 

chkResult.setBounds 

btnCancel.setBounds 

cmbRelation.setBounds 


(new Rectangle(4,2,93,18)); 
(new Rectangle(4,27, 93,18)); 
(new Rectangle(2,51, 93,18)); 
(new Rectangle(71,3, 114,17)); 
(new Rectangle(70,52, 114,17)); 
(new Rectangle(70,52,114,17)); 
(new Rectangle(138,77,49,22)); 
(new Rectangle(l, 77, 64,22)); 
(new Rectangle(72,77,60,22)); 
(new Rectangle(71, 28, 114, 17)); 


if (test.window.isDesign()){ 
loadDesignO; 

} 

else { 

loadSelectO; 

} 


btnOK.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnOK_actionPerformed(e); 

}}); 


btnCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnCancel_actionPerformed(e); 

}}); 


chkResult-setBorderPainted (true); 

cmbRelation.setBorder (null); 


chkResult.setFont (new java.awt.Font("Dialog", 0,11)); 
btnOK.setFont (new java.awt.Font("Dialog", 0, 11)); 
btnCancel.setFont (new java.awt.Font("Dialog", 0,11)); 
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btnOK.setBorder (BorderFactoiy.createRaisedBevelBorderQ); 

chkResult.setBorder (BorderFactoiy.createRaisedBevelBorderQ); 

btnCancel.setBorder (BorderFactoiy.createRaisedBevelBorder()); 

this.getContentPane().setLayout(null); 
this.getContentPaneQ.addClblName, null); 
this.getContentPane0.add(lblRelation, null); 
this.getContentPane().add(cmbRelation, null); 
this.getContentPane0.add(txtName, null); 
this.getContentPane0.add(lblCondition, null); 
if (test.window.isDesign()){ 
this.getContentPane().add(cmbDesignCondition, null); 

} 

else{ 

this.getContentPane().add(txtCondition, null); 

} 

this.getContentPane().add(btnCancel, null); 
this.getContentPane().add(chkResult, null); 
this.getContentPaneQ.addCbtnOK, null); 

this.setBounds(100,100,200,130); 
this.show(trae); 

} 


I* Set Methods */ 

* Sets the relation of the operator 

* ©parameter relation (String) 

**/ 

public void setRelation (String relation)! 
this.relation = relation; 

} 


/** 

* Sets the attribute list of the operator 

* ©parameter attributeList (String) 

public void setCondition (String condition)! 
this.condition = condition; 

} 


* Sets the name of the operator 

* ©parameter name (String) 
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public void setName (String name){ 
this.name = name; 

} 


/* Get Methods */ 

* Gets the input node number of the operator 

public int getnumberOfNodes(){ 
return this.NO_INPUT_NODES; 

} 


/** 

* Gets the type of the operator 
**/ 

public String getOperatorType(){ 
return this.OPERATOR_TYPE; 

} 


* Gets the relation of the operator 

public String getRelation (){ 
return this.relation; 

} 


/** 

* Gets the attribute list of the operator 

**f 

public String getCondition (){ 
return this.condition; 

} 


/** 

* Gets the name of the operator 

**f 

public String getName (){ 
return this.name; 

} 


/* WINDOW ACTIVATIONS */ 

f** 

* The window listener methods 

* @param event (WindowEvent) 

**/ 

public void windowClosing (WindowEvent event) {System.exit(O);} 
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public void window Activated (WindowEvent event) {} 

public void windowClosed (WindowEvent event) {} 

public void windowDeactivated (WindowEvent event) {} 
public void windowDeiconified (WindowEvent event) {} 
public void windowiconified (WindowEvent event) {} 

public void windowOpened (WindowEvent event) {} 

* button okay action performed 

* Takes the information entered for the operator. Creates a new operator and 

* calls add or change method of the draw class. And sends new operator 

* information there to be added to the list. 

* @param e (ActionEvent) 

**! 

void btnOK_actionPerformed(ActionEvent e) { 
if (chkResult.isSelected()){ 
display = true; 

} 

else{ 

display = false; 

} 

setName(txtName.getText()); 
setRelation((String)cmbRelation.getSelectedItem()); 
if (test.window.isDesign()){ 

setCondition((String)cmbDesignCondition.getSelectedItem()); 

else { 

setCondition(txtCondition.getText()); 

} 

String [] input = {getRelation(),getCondition(),"none","none"}; 
buildQueryO; 

if (!test.window.isDesign()){ 
if (whoIsCalling){ 
test.window.cnvDFQL.change 

(current,indexNum,x,y,getName(),getnumberOfNodes(), 

^ input,display, getOperatorType(Xquery); 

else{ 

test.window.cnvDFQL.add 

(x,y,getName(),getnumberOfNodes(),input,display, 

getOperatorType(),query); 

} 

else { 

test.window.designQueries.addElement(queiy); 



this.disposeO; 

} 

/** 

* Loads the relations with the tables of the selected database and previously 

* created operators. 

**! 

void loadSelectO { 

Vector deneme = test.window.currentDatabase.getTableNames(); 
if( IwhoIsCalling) { 

txtName.setText("Select"+test.window.Counter[0]-H-); 

} 

for (int index = 0; index < deneme.size(); index-H-) { 
cmbRelation.addItem((String) deneme.elementAt(index)); 

} 

for (int xi = 0; xi <test.window.cnvDFQL.numOfOperators;xi-H-) 
cmbRelation.addItem(test.window.cnvDFQL.operators[xi].name); 

cmbRelation.removeltem(name); 
if (relation = null) 
cmbRelation.setSelectedlndex(O); 
else 

cmbRelation. setSelectedltem(relation); 


* This portion of the code produces the SQL query for this operator according 

* to the information entered by user. 

**l 

public void buildQuery(){ 

String checkRelation = isOtherOperator (relation); 
if (checkRelation == null) { 
query = "select distinct * from" + relation; 

} 

else { 

query = "select distinct * from" + "(" +checkRelation +")"; 

} 

if (!(condition.equals(""))) { 
query = query +" where " + condition; 

} 

} 
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/** 

* button cancel action performed 

* terminates this frame without creating an operator, decrements the counter 

* @param e (ActiodEvent) 

**/ 

void btnCancel_actionPerformed(ActionEvent e) { 
test.window.Counter[0]-; 
this.disposeO; 

} 


* This portion of the code looks for the type of the relations, if they are 

* tables it returns null, otherwise if is another operator, it returns the 

* query of the operator which the current operator related to. 

public String isOtherOperator (String type) { 

String result = null; 

for (int index = 0; index < test.window.DFQLQuery.size(); index++) { 
Operator temp = (Operator) test.window.DFQLQuery.elementAt(index); 
if (type.equalsIgnoreCase(temp.name)). { 
result = temp.query; 
break; 

} 

} 

return result; 

} 




* This function is used to fill the combo boxes with the selection alternatives 

* if this operator is created as a part of a user defined operator then the 

* relation and condition combo boxes are filled with user defined operator 

* input items. 


private void loadDesign(){ 
txtName. setText(name); 

for (int index = 0; index < test.window.designRelation.size(); index-H-) { 
cmbRelation.addItem((String) test.window.designRelation.elementAt 
(index)); 


} 


for (int opindex = 0; oplndex < test.window.designOps.size(); opIndex-H-) 
if (!name.equalsIgnoreCase((String) test.window.designOps.elementAt 

(oplndex))) 

cmbRelation.addItem((String) test.window.designOps.elementAt 


} 


(oplndex)); 


{ 
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for (int conindex = 0; conindex < test.window.designCondition.sizeQ; 
conIndex++){ 

cmbDesignCondition.addItem 

(String)test.window.designCondition.elementAt(conlndex)); 

} 

} 

} 

25. OperatorUmon.Java 

package ThesisGUI; 

import java.awt.event.*; 
import java.io.*; 
import java.util.*; 
import java.awt.*; 
import javax.swing.*; 
import java.util. Vector; 
import javax.accessibility.*; 
import javax.swing.UIManager; 

* This frame is used to allow the user to enter the operator information 

* for union operator. It also allwos user to change the information 

* previously entered. 

* AUTHOR: IS & BA 

public class OperatorUnion extends JFrame implements WindowListener{ 

/** Type of the operator (constant) **/ 

final static String OPERATOR.TYPE = "Union"; 

/** Input node number of the operator (constant) **/ 
final static int NO_INPUT_NODES = 2; 

/** X coordinate of the operator**/ 
private int x; 

/** Y coordinate of the operator**/ 
private int y; 

/** name of the operator**/ 
private String name; 
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/** first input node relation**/ 
private String relation 1; 

/** second input node relation**/ 
private String relation2; 

/** display information for the operator**/ 
private boolean display = false; 

/** SQL query of the operator**/ 
private String query; 

/** Specify why this frame is called (to create a new one (false) 

* or change the current operator (true)**/ 
private boolean whoIsCalling = false; 

/** The index of the operator in the Operators list **/ 
private int indexNum; 

/** The index of the operator in the DFQLList**/ 
private int current; 

/** name label of the frame**/ 

JLabel IblName = new JLabel(); 

/** first relation label of the frame**/ 

JLabel IblRelationl = new JLabel(); 

/** second relation label of the frame**/ 

JLabel lblRelation2 = new JLabel(); 

/** text area to enter the name of the operator default diff#**/ 
JTextField txtName = new JTextField(); 

/** Okay button to confirm the info entered**/ 

JButton btnOK = new JButton(); 

/** check box for display information**/ 

JCheckBox chkResult = new JCheckBox(); 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelationl = new JComboBox(); 
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/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmbRelation2 = new JComboBox(); 

/** Button cancel to cancel this operation**/ 

JButton bmCancel = new JButton(); 

/* CONSTRUCTOR */ 

/** 

* Default constructor 

* ©parameters X and Y (integer) coordinates of the operator 

public OperatorUnion(int x, int y) { 
try { 

this.x = x; 
this.y = y; 
jbhiitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 

!** 

* Constructor with all parameters 

* ©parameters © parameters x, y, callerl, caller2 (integer), 

* name,relationl, relation2 (String), 

* display (boolean) 

**f 

public OperatorUnion(int x, int y, int callerl, int caller2, String name. 
String relation 1, String relation2, boolean display) { 
this.x = x; 

this.y = y; 

this.current = callerl; 

this.indexNum = caller2; 

this.whoIsCalling = trae; 

this.name = name; 

this.relationl = relation 1; 

this.relation2 = relation2; 

this.display = display; 

txtName.setText (name); 

if (display) { 

chkResult.setSelected(tme); 

} 
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else{ 

chkResult.setSelected(false); 

} 

try { 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 


* Design constructor 

* ©parameters name 
**/ 

public OperatorUnion(String name) { 
try { 

this.name = name; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 



INITIATE METHOD 


*/ 


* The initiation 

* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 


private void jblnitO throws 
IblName.setText 
this.setTitle 
IblRelation 1 .setText 
lblRelation2.setText 
btnOK.setText 
btnCancel.setText 
chkResult.setText 


Exception { 
("Name"); 
("Union"); 
("Relation 1"); 
("Relation2"); 
("OK"); 
("Cancel"); 
("Display"); 


IblName.setBounds 
IblRelation 1 .setBounds 
lblRelation2. setBounds 
chkResult.setBounds 
cmbRelation 1 .setBounds 


(new Rectangle(4, 2,93,18)); 
(new Rectangle(4,27,93,18)); 
(new Rectangle(4, 50,93, 18)); 
(new Rectangle(2,78,56,22)); 
(new Rectangle(80,28, 114, 17)); 
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cmbRelation2.setBounds (new Rectangle(80,51, 114,17)); 

btnCancel.setBounds (new Rectangle(71,78,60,23)); 

txtName.setBounds (new Rectangle(80,2,114,17)); 

btnOK.setBounds (new Rectangle(143,78,52,22)); 

if (test.window.isDesign()){ 
loadDesignO; 

} 

else { 

loadSelectO; 

} 

btnOK.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnOK_actionPerformed(e); 

}}); 

btnCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPeiformed(ActionEvent e) { 
btnCancel_actionPerfomied(e); 

}}); 

chkResult.setBorderPainted (true); 

cmbRelation 1 .setBorder (null); 

cmbRelation2.setBorder (null); 

chkResult.setFont (new java.awt.Font("Dialog", 0, 11)); 
btnCancel.setFont (new java.awt.Font("Dialog", 0, 11)); 
btnOK.setFont (new java.awt.Font("Dialog", 0, 11)); 

btnOK.setBorder (BorderFactory.createRaisedBevelBorderO); 

chkResult. setBorder (BorderFactory.createRaisedBevelBorderO); 

btnCancel.setBorder (BorderFactory.createRaisedBevelBorderO); 

this.getContentPane(). setLayout(null); 
this.getContentPane().add(lblName, null); 
this.getContentPane(). add(txtN ame, null); 
this.getContentPane().add(lblRelation 1, null); 
this.getContentPane().add(cmbRelationl, null); 
this.getContentPane().add(cmbRelation2, null); 
this.getContentPane().add(lblRelation2, null); 
this.getContentPane().add(clikResult, null); 
this.getContentPane().add(btnCancel, null); 
this.getContentPane().add(btnOK, null); 

this.setBounds(100,100,210,140); 
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this.show(true); 

} 


/* Set Methods */ 

* Sets the first relation of the operator 

* ©parameter relation 1 (String) 

public void setRelationl (String relation 1){ 
this.relationl =relationl; 

} 

/** 

* Sets the second relation of the operator 

* ©parameter relation2 (String) 

public void setRelation2 (String relation2){ 
this.relation2 = relation2; 

} 


* Sets the name of the operator 

* ©parameter name (String) 

public void setName (String name){ 
this.name = name; 

} 


/* Get Methods */ 

!** 

* Gets the number of the input nodes of the operator 
**/ 

public int getnumberOfNodes(){ 
return this.NO_INPUT_NODES; 

} 


/** 

* Gets the type of the operator 
**/ 

public String getOperatorType(){ 
return this.OPERATOR_TYPE; 

} 
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* Gets the first relationof the operator 

public String getRelationl (){ 
return this.relationl; 

} 


* Gets the second relation of the operator 

**! 

public String getRelation2 (){ 
return this.relationl; 

} 


* Gets the name of the operator 
**/ 

public String getName (){ 
return this.name; 

} 


/* WINDOW ACTIVATIONS */ 

!** 


* The window listener methods 

* @param event (WindowEvent) 

public void windowClosing 
public void window Activated 
public void windowClosed 
public void windowDeactivated 
public void windowDeiconified 
public void windowiconified 
public void windowOpened 


(WindowEvent event) {System.exit(0);} 
(WindowEvent event) {} 
(WindowEvent event) {} 
(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 

(WindowEvent event) {} 


* button okay action performed 

* Takes the information entered for the operator. Creates a new operator and 

* Calls add or change method of the draw class. And sends new operator 

* information there to be added to the list. 

* @param e (ActionEvent) 

void bmOK_actionPerformed(ActionEvent e) { 
if (chkResult.isSelected()){ 
display = true; 

} 

else{ 
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display = false; 

} 

setName(txtName.getText()); 

setRelation 1 ((String)cmbRelation 1 .getSelectedItem()); 

setRelation2((String)cmbRelation2.getSelectedItem()); 

String [] input = {getRelationl(),getRelation2(),"none","none"}; 
buildQueryO; 

if (!test.window.isDesign()){ 
if (whoIsCalling){ 
test.window.cnvDFQL.change 

(current,indexNuni,x,y,getName(),getnumberOfNodes(), 
input,display, getOperatorType(), query); 

} 

else{ 

test.window.cnvDFQL.add 

(x,y,getName(),getnumberOfNodes(),input,display, 
getOperatorTypeO, query); 

} 

} 

else { 

test.window.designQueries.addElement(query); 

} 

this.disposeO; 

} 


* Loads the relations with the tables of the selected database and previously 

* created operators. 

**/ 

void loadSelectO { 
if(!whoIsCalling){ 

txtName.setText("Union"+test.window.Counter[3]++); 

} 

Vector deneme = test.window.currentDatabase.getTableNames(); 
for (int index = 0; index < deneme. size(); index++) { 
cmbRelation 1 .addItem((String) deneme.elementAt(index)); 
cmbRelation2.addItem((String) deneme.elementAt(index)); 

} 

for (int xi = 0; xi <test.window.cnvDFQL.numOfOperators;xi-H-){ 
cmbRelationl.addItem(test.window.cnvDFQL.operators[xi].name); 
cmbRelation2.addItem(test.window.cnvDFQL.operators[xi].name); 


284 



cmbRelation 1 .removeItem(name); 
cmbRelation2.removeItem(name); 

if (relation 1= null) 
cmbRelation 1. setSelectedIndex(0); 
else 

cmbRelation 1. setSelectedItem(relation 1); 
if (relation2= null) 
cmbRelation2.setSelecteciLidex(0); 
else 

cmbRelation2.setSelectedItem(relation2); 


* button cancel action performed 

* terminates this frame without creating an operator, decrements the counter 

* @param e (ActionEvent) 

**/ 

void btnCancel_actionPerformed(ActionEvent e) { 
test.window.Counter[3]—; 
this.disposeO; 

} 


/** 

* This portion of the code produces the SQL query for this operator according 

* to the information entered by user. 

**! 

public void buildQuery(){ 

String checkRelation = isOtherOperator (relation 1); 
if (checkRelation = null) { 

query = "select distinct * from" + relation 1+" union 

} 

else { 

query = "select distinct * from" + "(" +checkRelation +") union "; 

} 

checkRelation = isOtherOperator(relation2); 

if (checkRelation = null) { 
query = query + ^'select distinct * from " + relation2; 

} 

else { 

query = query + "select distinct * from " +"(" +checkRelation + ")"; 

} 
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* This portion of the code looks for the type of the relations, if they are 

* tables it returns null, otherwise if is another operator, it returns the 

* query of the operator which the current operator related to. 

**/ 

public String isOtherOperator (String type) { 

String result = null; 

for (int index = 0; index < test.window.DFQLQuery.sizeQ; index-H-) { 
Operator temp = (Operator) test.window.DFQLQueiy.elementAt(index); 
if (type.equalsIgnoreCase(temp.name)) { 
result = temp.query; 
break; 

} 

} 

return result; 

} 


* This function is used to fill the combo boxes with the selection alternatives 

* if this operator is created as a part of a user defined operator then the 

* relation and condition combo boxes are filled with user defined operator 

* input items. 


private void loadDesign(){ 
txtName. setText(name); 


for (int index = 0 ; index < test.window.designRelation.size(); index-H-) { 
cmbRelation 1 .addItem((String) test.window.designRelation.elementAt 

(index)); 

cmbRelation2.addItem((String) test.window.designRelation.elementAt 

(index)); 


} 


for (int opindex = 0 ; opindex < test.window.designOps.size(); opIndex-H-) { 
if (!name.equalsIgnoreCase((String) test.window.designOps.elementAt 

(opindex)))! 

cmbRelation 1 .addItem((String) test.window.designOps.elementAt 

(opindex)); 

cmbRelation2.addItem((String) test.window.designOps.elementAt 

(opindex)); 

} 

} 

} 

} 
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26. OperatorUsenJava 


package ThesisGUI; 

import j ava.awt.event. *; 
import java.io.*; 
import java.util.*; 
import j ava.awt. *; 
import javax.swing. *; 
import java.util. Vector; 
import javax.accessibility.*; 
import javax.swing.UIManager; 

!** 

* This frame is used to create user defined operators. User enters 

* the numbers of the relation, attribute and conditions of the new 

* operator and selects which operators are going to be used to create 

* the new one. 

* AUTHOR: IS & BA 

public class OperatorUser extends JFrame implements WindowListener { 

/** Type of the operator (constant) **/ 

String operatorType; 

/** Input node number of the operator (constant) **/ 
int noOfInputNodes; 

/** X coordinate of the operator**/ 
private int x; 

/** Y coordinate of the operator**/ 
private int y; 

/** name of the operator**/ 
private String name; 

/** input node relation**/ 

private String [] inputNodes = {}; 

/** display information for the operator**/ 
private boolean display = false; 

/** SQL query of the operator**/ 
private String querySkeleton; 
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/** SQL query of the operator**/ 
private String query; 

/** name label of the frame**/ 

JLabel IblName = new JLabelQ; 

/** relation label of the frame**/ 

JLabel Ibllnputl = new JLabelQ; 

/** relation label of the frame**/ 

JLabel lblhiput2 = new JLabelQ; 

/** relation label of the frame**/ 

JLabel IblInputS = new JLabelQ; 

/** relation label of the frame**/ 

JLabel lbllnput4 = new JLabelQ; 

/** text area to enter the name of the operator default diff#**/ 
JTextField txtName = new JTextFieldQ; 

/** Okay button to confirm the info entered**/ 

JButton btnOK = new JButtonQ; 

/** check box for display information**/ 

JCheckBox chkResult = new JCheckBoxQ; 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmblnputl = new JComboBoxQ; 

/** Combo box lists the available operators or table names that can be 

* related to this operator**/ 

JComboBox cmblnput2 = new JComboBoxQ; 

/** Button cancel to cancel this operation**/ 

JButton btnCancel = new JButtonQ; 

/** text area to enter the group attribute list of the operator **/ 
JTextField txtlnput2 = new JTextFieldQ; 

/** text area to enter the count attribute list of the operator **/ 
JTextField txtInputS = new JTextFieldQ; 

/** text area to enter the condition number of the operator **/ 
JTextField txtlnput4 = new JTextFieldQ; 
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/** number of the relations **/ 
private int noOfRelations; 

/** number of the conditions **/ 
private int noOfConditions; 

/** number of the attributes **/ 
private int noOfAttributes; 

/* CONSTRUCTOR *! 

f** 

* Default constmctor 

* ©parameters X and Y (integer) coordinates of the operator 


public OperatorUser(int x, int y, int relation, int condition, int attribute. 
String skeleton. String type) { 


try { 
this.x 
this.y 

this.noOfRelations 

this.noOfConditions 

this.noOfAttributes 

this .noOfInputNodes 

this.querySkeleton 

this. operatorType 

jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 


= x; 

=y; 

= relation; 

= condition; 

= attribute; 

= relation + condition + attribute; 
= skeleton; 

= type; 


} 


/* INITIATE METHOD */ 

/** 

* The initiation 

* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 

**! 

private void jblnit() throws Exception { 

Vector labels = new Vector(); 

for (int rellndex = 1; relLidex <= noOfRelations; relIndex++){ 
labels.addElement("Relation"+relIndex); 

} 
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for (int conindex = 1; conindex <= noOfConditions; conIndex-H-){ 
labels.addElement("Condition"+conIndex); 

} 

for (int attindex = 1; attindex <= noOfAttributes; attIndex-H-){ 
labels.addElement("Attribute"+attIndex); 

} 

btnOK.setText ("OK"); 

btnCancel.setText ("Cancel"); 
chkResult.setText ("Display"); 

IblName.setText ("Name"); 
this.setTitle (operatorType); 

IblName.setBounds (new Rectangle(4,2,93,18)); 

IblInputl.setBounds (new Rectangle(3,24,93,18)); 

lblInput2.setBounds (new Rectangle(4,47, 93,18)); 

lblInput3.setBounds (new Rectangle(4,70,93,18)); 

lblInput4.setBounds (new Rectangle(4, 95, 68, 16)); 

txtName.setBounds (new Rectangle(80, 2, 114, 17)); 

txtInput2.setBounds (new Rectangle(80,48, 114, 17)); 

txtInput3.setBounds (new Rectangle(80, 71, 114, 17)); 

txtInput4.setBounds (new Rectangle(80,95, 114, 17)); 

cmbInputl.setBounds (new Rectangle('79,25,114,17)); 

cmbInput2.setBounds (new Rectangle(80,48, 114, 17)); 

btnOK-setBounds (new Rectangle( 142, 117, 51,22)); 

btnCancel.setBounds (new Rectangle(73,117,60, 23)); 
chkResult-setBounds (new Rectangle(5, 117, 58, 22)); 

txtName.setText (operatorType); 

loadSelectO; 

btnOK.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnOK_actionPerformed(e); 

}}); 

btnCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
btnCancel_actionPerformed(e); 

}}); 
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cmblnputl .setBorder 
cmbInput2.setBorder 
chkResult-setBorderPainted 


(null); 

(null); 

(true); 


chkResultsetFont (new java.awt.Font("Dialog", 0,11)); 
btnOK-setFont (new java.awt.Font("Dialog", 0,11)); 
btnCancel.setFont (new java.awt.Font("Dialog", 0,11)); 

btnOK.setBorder (BorderFactory.createRaisedBevelBorderO); 

chkResult.setBorder (BorderFactory.createRaisedBevelBorder()); 

btnCancel.setBorder (BorderFactory.createRaisedBevelBorder()); 

this.getContentPane().setLayout(null); 
this.getContentPane().add(lblName, null); 
this.getContentPane().add(txtName, null); 

if (noOfInputNodes > 3){ 
lblInput4.setText ((String)labels.elenientAt(3)); 
this.getContentPane().add(lblInput4, null); 
this.getContentPane().add(txtInput4, null); 

} 

if (noOfInputNodes > 2){ 
lblInput3.setText ((String)labels.elementAt(2)); 
this.getContentPane().add(lblInput3, null); 
this.getContentPane().add(txtInput3, null); 

} 

if (noOfInputNodes > 1){ 
lblInput2.setText ((String)labels.elementAt( 1)); 
this.getContentPane().add(lblInput2, null); 
if (noOfRelations > 1) { 
this.getContentPane().add(cmbInput2, null); 

} 

else { 

this.getContentPane().add(txtInput2, null); 

} 

} 

if (noOfInputNodes > 0){ 

Ibllnputl .setText ((String)labels.elenientAt(O)); 
this.getContentPane(),add(lblbiputl, null); 
this.getContentPane().add(cmbInputl, null); 

} 

this.getContentPane().add(chkResult, null); 
this.getContentPane().add(btnCancel, null); 
this.getContentPane().add(btnOK, null); 
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this.setBounds(100,100,210,180); 
this.show(true); 

} 

/* Set Methods */ 

/** 

* Sets the name of the operator 

* ©parameter name (String) 

**f 

public void setName (String name){ 
this.name = name; 

} 

/* Get Methods */ 

* gets the input number of the operator 

**/ 

public int getnumberOfNodes(){ 
return this.noOfInputNodes; 

} 

/** 

* gets the type of the operator 

**l 

public String getOperatorType(){ 
return this.operatorType; 

} 

/** 

* gets the relation of the operator 

**f 

public String gethiputl (){ 
return (String)cmblhputl .getSelectedItem(); 

} 

* gets the group Attribute list of the operator 
**/ 

public String getlnput2 (){ 
if (noOfRelations > 1){ 
return (String)cmbInput2.getSelectedItem(); 

} 

else { 

return txthiput2.getText(); 

}} 
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!** 

* gets the condition of the operator 
**! 

public String getInputS (){ 
return txtInput3.getText(); 

} 

* gets the condition of the operator 

public String getlnput4 (){ 
return txtInput4.getText(); 

} 

/** 

* gets the name of the operator 
**/ 

public String getName (){ 
return this.name; 

} 

/* WINDOW ACTIVATIONS */ 

/** 

* The window listener methods 

* @param event (WindowEvent) 

**/ 

public void windowClosing (WindowEvent event) {System.exit(0);} 

public void window Activated (WindowEvent event) {} 

public void windowClosed (WindowEvent event) {} 

public void windowDeactivated (WindowEvent event) {} 

public void windowDeiconified (WindowEvent event) {} 

public void windowiconified (WindowEvent event) {} 

public void windowOpened (WindowEvent event) {} 

/** 

* button okay action performed 

* Takes the information entered for the operator. Creates a new operator and 

* calls add or change method of the draw class. And sends new operator 

* information there to be added to the list. 

* @param e (ActionEvent) 

**f 

void btnOK_actionPerformed(ActionEvent e) { 
if(chkResult.isSelected()) { 
display = true; 

} 



else{ 

display = false; 

} 

setNanie(txtName.getText()); 

if (noOfInputNodes > 3) 
inputNodes[3] = getfiiput4(); 
if (noOfInputNodes > 2) 
inputNodes[2] = getlnput3(); 
if (noOfInputNodes > 1) 
inputNodes[l] = getlnput2(); 
if (noOfbiputNodes > 0) 
inputNodes[0] = getLiputl(); 

buildQueryO; 

System.out.println(query); 
test, window .cnvDFQL.add 

(x,y,getName(),getnumberOfNodes(),inputNodes,display, 
getOperatorTypeO, query); 

this.disposeO; 

} 


* Loads the relations with the tables of the selected database and previously 

* created operators. 

void loadSelectO { 

Vector deneme = test.window.currentDatabase.getTableNames(); 
for (int index = 0 ; index < deneme. size(); index++) { 
cmblnputl .addItem((String) deneme.elementAt(index)); 
cmbInput2.addItem((String) deneme.element At(index)); 


for (int xi = 0; xi <test.window.cnvDFQL.numOfOperatofs;xi++){ 
cmblnputl.addItem(test.window.cnvDFQL.operators[xi].name); 
cmbInput2.addItem(test.window.cnvDFQL.operators[xi].name); 

cmblnputl .removeltem(name); 
cmbInput2.removeItem(name); 

} 


* button cancel action performed 

* terminates this frame without creating an operator, decrements the counter 

* @param e (ActionEvent) 
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void btnCancel_actionPerformed(ActionEvent e) { 
this.disposeO; 

} 


!** 

* This portion of the code produces the SQL query for this operator according 

* to the information entered by user. 

**j 

public void buildQuery(){ 


StringBuffer skeleton 
StringBuffer result; 
String temp; 

String tempToken 
int inputCount 
int lastindex 
String checkRelation 
boolean last 


= new StringBuffer(querySkeleton); 


= 0 ;’ 

= 0; 

= null; 
= false; 


// Check the relation slots in the query skeleton and replace them with the 
names 

// of the relations entered by the user 

for (int relindex = 1; relindex <= noOfRelations; relIndex-H-){ 
temp = "Rel" + relindex; 
result = new StringBuffer(); 

for (int bufferindex = 0; bufferbidex < skeleton.length()-3; bufferIndex++){ 
tempToken = skeleton.substring(bufferIndex, bufferlndex44); 
if (temp.equalsIgnoreCase(tempToken)) { 
checkRelation = isOtherOperator (inputNodes[inputCount]); 
if (bufferindex = skeleton.length()-4){ 
last = true; 

} 

if (checkRelation = null){ 
result = result.append(inputNodes[inputCount]); 

} 

else{ 

result = result.append("("+ checkRelation+ ")"); 

} 

bufferindex = bufferindex + 3; 

} 

else{ 

result = result.append(skeleton.charAt(bufferIndex)); 


} 

if (Hast) { 
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result = result.append(skeleton.substring(skeleton.length()-3, 
skeletonJengthQ)); 

} 

else{ 

last = false; 

} 

inputCount-H-; 
skeleton = result; 

} 

// Check the condition slots in the query skeleton and replace them with 
// the names of the conditions entered by the user 
for (int conindex = 1; conindex <= noOfConditions; conIndex-H-){ 
result = new StringBuffer(); 
temp = "Con" + conindex; 

for (int bufferindex = 0; bufferindex < skeleton.length()-3; bufferIndex-H-){ 
tempToken = skeleton.substring(bufferIndex, bufferIndex+4); 
if (temp.equalsIgnoreCase(tempToken)) { 
if (bufferindex == skeleton.length()-4) { 
last = tme; 

} 

result = result.append(inputNodes[inputCount]); 
bufferindex = bufferindex + 3; 

} 

else{ 

result = result.append(skeleton.charAt(bufferIndex)); 

} 

lastindex = bufferIndex+1; 

} 

if(!last){ 

result = result.append(skeleton.substring(lastIndex,skeleton.length())); 

else{ 

last = false; 

} 

inputCount-H-; 
skeleton = result; 

} 

// Check the attribute slots in the query skeleton and replace them with the 
names 

// of the attribute names entered by the user 
for (int attindex = 1; attindex <= noOfAttributes; attIndex++){ 
temp = "Att" + attindex; 
result = new StringBuffer(); 

for (int bufferindex = 0; bufferindex < skeleton.length()-3; bufferIndex-H-){ 
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tempToken = skeleton.substring(bufferIndex, bufferIndex+4); 
if (temp.equalsIgnoreCase(tempToken)){ 
if (bufferlndex = skeleton.length()-4){ 
last = trae; 

} 

result = result.append(inputNodes[inputCount]); 
bufferlndex = bufferlndex + 3; 

} 

else{ 

result = result.append(skeleton.charAt(bufferIndex)); 

} 

} 

if (!last){ 

result = result.append(skeleton.substring(skeleton.length()-3, 
skeleton.lengthO)); 

} 

else{ 

last = false; 

} 

inputCount-H-; 
skeleton = result; 

} 

this.query = skeleton.toStringQ; 

} 


* This portion of the code looks for the type of the relations, if they are 

* tables it returns null, otherwise if is another operator, it returns the 

* query of the operator which the current operator related to. 

**/ 

public String isOtherOperator (String type) { 

String result = null; 

for (int index = 0; index < test.window.DFQLQuery.size(); index++) { 
Operator temp = (Operator) test.window.DFQLQuery.elementAt(index); 
if (type.equalsIgnoreCase(temp.name)) { 
result = temp.query; 
break; 

} 

} 

return result; 

} 

} 
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27. PrmtPreview.Java 


package ThesisGUI; 

import java.awt.*; 
import javax.swing. *; 
import java.awt.print.*; 

public class PrintPreview implements Printable { 
private Component componentToBePrinted; 

public static void printComponent(Component c) { 
new PrintPreview(c).print(); 

} 

public PrintPreview(Component componentToBePrinted) { 
this.componentToBePrinted = componentToBePrinted; 


public void printQ { 

PrinterJob piinJob = PrinterJob.getPrinterJob(); 
printJob.setPrintable(this); 
if (printJob.printDialogO) 
try { 

printJob.printO; 

} catch(PrinterException pe) { 

System.out.println("Error printing: " + pe); 

} 

public int print(Graphics g, PageFormat pageFormat, int pageindex) { 
if (pageindex > 0) { 
retum(NO_SUCH_PAGE); 

} 

else { 

Graphics2D g2d = (Graphics2D)g; 

g2d.translate(pageFormat.getImageableX(), pageFormat.getImageableY()); 

disableDoubleBuffering(componentToBePrinted); 

componentToBePrinted.paint(g2d); 

enableDoubleBuffering(componentToBePrinted); 

retum(PAGE_EXISTS); 

} 

} 


298 




/** The speed and quality of printing suffers dramatically if 

* any of the containers have double buffering turned on. 

* So this turns if off globally. 

* @see enableDoubleBuffering 

*1 

public static void disableDoubleBuffering(Component c) { 

RepaintManager currentManager = RepaintManager.currentManager(c); 
currentManager.setDoubleBufferingEnabled(false); 

} 

/** Re-enables double buffering globally. */ 

public static void enableDoubleBuffering(Component c) { 

RepaintManager currentManager = RepaintManager.currentManager(c); 
currentManager.setDoubleBufferingEnabled(true); 

} 

} 

28. Relation.Jaya 

package ThesisGUI; 

import j ava.util. *; 
import javax.swing.table.*; 

/** 

* This class implements the necessary model JTable, so the JTable object and 

* display the rows of data 

* 

* AUTHOR : BA & IS 

public class Relation extends AbstractTableModel{ 

Vector columnNames; 

Vector rows; 

// Default constructor 
public Relation (){ 
rows = new VectorQ; 

columnNames = new VectorQ; 

) 

// Assigns the table content and the column heading 
public void assignData(Vector tableData, Vector columnHeader) { 
this.rows = tableData; 
this.columnNames = columnHeader; 
fireTableChanged(null); 

} 
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// Table Model Implementation 

public String getColumnName(int column) { 

String result = 

if (columnNames.elementAt(column) != null) { 

Attribute temp = (Attribute)columnNames.elementAt(colunin); 

result = temp.getAttributeNameQ; 

} 

return result; 

} 

public int getColumnCountQ { 
return columnNames.sizeQ; 

} 

public int getRowCount() { 
return rows.size(); 

} 

public Object getValueAt (int aRow, int aColunm) { 

Vector row = (Vector)rows.elementAt(aRow); 
return row.elementAt(aColumn); 

} 

public void clear (){ 
this.rows.removeAllElementsO; 
this.columnNames.removeAllElementsO; 
fireT ableChanged(null); 

} 

} 

29. SaveConfig.Java 


package ThesisGUI; 
import java.awt. *; 
import javax.swing.*; 
import java.awt.event.*; 
import javaio.*; 
import java.util.*; 

* This frame is designed to be used to save a query, 

* that is created by the user, for future use. 

* AUTHOR : IS & BA 
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public class saveConfig extends JFrame { 

/** File Dialog object for saving a file **/ 

FileDialog file = new FileDialog(this,"Save File",FileDialog.SAVE); 
/** 

* Boolean TRUE : if user wants to save a user defined operator 

* FALSE: if user wants to save a DFQL Query 

**/ 

boolean userDefined = false; 

// The fields required in order to save a user defined operator 
int xCoord, yCoord, relNo, conNo, attNo; 

String querySkel, opType; 

/* CONSTRUCTORS */ 

/** 

* The default constructor 
**/ 

public saveConfigO { 
try { 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceQ; 

} 

} 

/** 

* The constructor to save a user defined operator 

**! 

public saveConfig(int x, int y, int rel, int cond, int att. String skeleton, 


try { 

String type) { 

userDefined 

= true; 

xCoord 

= x; 

yCoord 

= y; 

relNo 

= rel; 

conNo 

= cond; 

attNo 

= att; 

queiySkel 

= skeleton; 

opType 

jblnitO; 

= type; 


} 

catch(Exception e) { 
e.printStackTraceQ; 
}} 
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/* INTTIATE METHOD */ 

/** 

* The initiation 

* creates the file dialog object. And inititates it. 

* Later on calls save config method. 

private void jblnit() throws Exception { 
this.setResizable (false); 

// If user wants to save a user defined operator, set the file type to ".uso" 
if (userDefined){ 

file.setDirectory ("d:\\JBuilder3\\myprojects\\ThesisGUI\\operator\\"); 
file.setFile ("*.uso"); 
saveDesign (); 

} 

// If user wants to save a DFQL queiy, set the file type to ".dfql" 
else { 

file.setDirectory ("d:\\JBuilder3\\myprojects\\ThesisGlJI\\"); 
file.setFile ("*.dfql"); 
saveConfig (); 

} 


* Checks the name of the file. If a file is entered. It starts to write 

* the operator data to file. It repeats the same procedure 

* for every operator created in the DFQL query to be saved. 

**/ 

void saveConfig(){ 
file.show(true); 

String fileName = file.getFile(); 
if (fileName !=null){ 
try { 

File newFile = new File (file.getDirectoiy()+ fileName); 

FileWriter outStream = new FileWriter (newFile); 

BufferedWriter bufFile = new BufferedWriter (outStream); 

bufFile.write(test.window.DFQLQuery.size()+"\n"); 

for(int xi =0;xi<test.window.DFQLQuery.size();xi-H-){ 

Operator temp = (Operator)test.window.DFQLQuery.elementAt(xi); 
bufFile. write(temp.type+"\n"); 
bufFile.write(temp.name+"\n"); 
bufFile.write(temp.x+"\n"); 



bufFile.write(temp.y+"\n"); 

bufFile.write(temp.numberOfDiputNodes+"\n"); 

bufFile.write(temp.display+"\n"); 

bufFile.write(temp.query+"\n"); 

for(int fi=0;fi<temp.numberOfEnputNodes;fi-H-) { 
bufFile.write(temp.input[fi]+"\n"); 

} 

} 

bufFile.closeO; 

} 

catch (lOException ex){} 

} 

} 


* Checks the name of the file. If a file is entered. It starts to write 

* the user defined operator data to file. 

**! 

void saveDesign(){ 
file.show(true); 

String fileName = file.getFileQ; 
if (fileName !=null){ 
try { 

File newFile = new File (file.getDirectoiyO+fileName); 
FileWriter outStream = new FileWriter (newFile); 
BufferedWriter bufFile = new BufferedWriter (outStream); 

bufFile.write(xCoord+"\n"); 
bufFile.write(yCoord+"\n"); 
bufFile.write(relNo+"\n"); 
bufFile. write(conNo+"\n"); 
bufFile.write(attNo+"\n"); 
bufFile.write(querySkel+"\n'’); 
bufFile. write(opType+"\n"); 
bufFile.closeO; 

} 

catch (lOException ex){} 

} 

} 

} 
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30. Settings.Java 


package ThesisGUI; 

import java.awt.*; 
import javax.swing.*; 
import java.awt.event.*; 

* This class is used to provide the user an interface to change performance 

* related attributes of the connected database. There are three important settings 

* for the database connection: Store, AskDB, and UpdatePeriod 

* ©author BA & IS 

* ©see Database-store 

* ©see Database-askDB 

* ©see Database-updatePeriod 
**! 

public class Settings extends JFrame { 

JCheckBox checkBoxStore 
JCheckBox checkBoxAskDB 
JLabel labelUpdateTime 
JTextField txtUpdateTime 
JButton buttonOK 
JButton buttonCancel 

private Database setDatabase; 

public Settings (Database cuirentDatabase) { 
try { 

setDatabase = cuirentDatabase; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 

private void jblnit() throws Exception { 
this.setResizable(false); 
this.getContentPane().setLayout(null); 
this.setBounds(new Rectangle(250,180,270,200)); 
this.setTitleC'Settings -"+ setDatabase.getURLO); 

checkBoxStore.setHorizontalTextPosition(SwingConstants.LEADING); 
checkBoxStore.setTextC'Store Executed Queries "); 


= new JCheckBoxO; 

= new JCheckBoxO; 

= new JLabelO; 

= new JTextFieldO; 

= new JButtonC'OK"); 

= new JButtonC'Cancel"); 
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checkBoxStore.setHorizontalAligninent(SwingConstants.LEADING); 
checkBoxStore.setBounds (new Rectangle(32,9,173,25)); 
checkBoxStore.setSelected(setDatabase.isStore()); 
checkBoxStore.setBorder (BorderFactory.createEtchedBorder()); 

checkBoxAskDB.setHorizontalTextPosition(SwingConstants.LEADING); 
checkBoxAskDB.setText ("Get results from Database"); 
checkBox AskDB .setHorizontal Alignment(S wingConstants.LEADING); 
checkBoxAskDB.setBounds (new Rectangle(32,47,173,25)); 

checkBoxAskDB.setSelected (setDatabase.isAskDB()); 

checkBoxAskDB.setBorder (BorderFactory.createEtchedBorderO); 


labelUpdateTime.setText ("Enter Update Time (mins)"); 

labelUpdateTime.setBounds (new Rectangle(35,92,143,25)); 


txtUpdateTime.setBounds (new Rectangle(180, 94,47,20)); 

txtUpdateTime.setText(Integer.toString(setDatabase.getUpdateTime())); 


buttonOK.setText("OK"); 

buttonOK.setBounds(new Rectangle(70,135,90,20)); 
buttonOK.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
buttonOK_actionPerformed(e); 

}}); 


buttonCancel.setTextC'Cancel"); 

buttonCancel.setBounds ((new Rectangle(170,135,90,20))); 
buttonCanceI.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
buttonCancel_actionPerformed(e); 

}}); 

this.getContentPane().add(checkBoxStore, null); 
this.getContentPane().add(labelUpdateTime, null); 
this.getContentPane().add(checkBoxAskDB, null); 
this.getContentPane().add(txtUpdateTime, null); 
this.getContentPane().add(buttonOK, null); 
this.getContentPane().add(buttonCancel, null); 

} 


void buttonOK_actionPerformed(ActionEvent e) { 
setDatabase.setStore(checkBoxStore.isSeIected()); 
setDatabase.setAskDB(checkBoxAskDB.isSelected()); 
setDatabase.setUpdatePeriod(Integer.parseInt(txtUpdateTime.getText())); 
this.disposeO; 

} 
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void buttonCancel_actionPerformed(ActionEvent e) { 
this.disposeO; 

} 

} 

31. TabIe.Jaya 

package ThesisGUI; 

import java.util.*; 
import java.util.Date; 
import java.lang.*; 
import java.sql.*; 

/** 

* This class holds the information (Relation name, data, attributes, owner, 

* query to get this relation) of a relation. 

* ©author BA 

**/ 

public class Table { 

/* DATA MEMBERS */ 

!** 

* Updates the query data after this period 
private int consTime; 

/** 

* Relation Name 
**/ 

private String name; 

j** 

* Attributes of this relation 
**/ 

private Vector attributes; 

* Owner Database of this relation 

**/ 

private Database owner; 
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!** 

* The relation's data 

**! 

private Vector data; 

* Query to get this relation 

**! 

private String query; 

* The time when the query is executed 
private Date tStamp; 


/* CONSTRUCTORS */ 

* Constructor 

* @param queryl the query to get this relation 

* ©dBase Owner of this relation (Database object) 

* ©see Database 

**/ 

protected Table (String queryl, Database dBase) throws SQLException{ 

// Name of the relation 
// Owner database of this relation 
// Attributes of this relation 
// Data of this relation 
// Query to get this relation 
// Timestamp 


name 

= null; / 

owner 

= dBase; 

attributes 

= new VectorO; 

data 

= new VectorO; 

query 

= queryl; 

tStamp 

= new DateQ; 


} 


// finds and stores the attributes of this relation 
inidateRelationAttributesO; 

// stores the relation data in the data vector 
initiateDataO; 


/* PUBLIC METHODS */ 

/** 

* ©return the table name (String) 

public String getTableName(){ 
return name; 

} 
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!** 

* ©return The relation's attributes (Vector of Attribute Class) 

* @see Attribute Class 
**/ 

public Vector getAttributes(){ 
return attributes; 

} 

* ©return The relation's attribute names (Vector of String) 

**! 

public Vector getAttributeNames (){ 

Vector attNames = new Vector(); 

for (int attindex = 0; atthidex < attributes.size(); attlndex++) { 
Attribute att = (Attribute) attributes.elementAt(attlndex); 
attNames.add(att.getAttributeName()); 

} 

return attNames; 

1 

/** 

* ©return The relation data (Vector) 

**/ 

public Vector getData() throws SQLException{ 
return data; 

} 

!** 

* ©return the query to get this relation (String) 

public String getQuery(){ 
return query; 

} 

public Attribute getAttData (String attName) { 

Attribute result = null; 

for (int attindex = 0; attindex < attributes.size(); attIndex-H-) { 
result = (Attribute) attributes.elementAt(attIndex); 
if (result.getAttributeName().equalsIgnoreCase(attName)) { 
break; 

} 

} 

return result; 

} 
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/* PRIVATE METHODS */ 

!** 

* Stores the Attribute information of the current query 
private void initiateRelationAttributes()throws SQLException{ 


ResultSetMetaData metaData = owner.getQueryMetaDataQ; 

int resultColumnCount = metaData.getColunmCount(); 


for (int columnindex = 1; columnlndex <= resultColumnCount; 
columnlndex-H-) { 

Attribute temp = new AttributeO; 

temp.setAttributeName(metaData.getColumnName(colunmIndex)); 
temp.setAttributeType (metaData.getColumnTypeName(columnIndex)); 
temp.setAttributeSize (metaData.getColumnDisplaySize(columnIndex)); 
temp.setNullable (metaData.isNullable(columnIndex)); 

temp.setSearchable (metaData.isSearchable(columnIndex)); 
temp.setCaseSensitive (metaData.isCaseSensitive(colunuiIndex)); 
attributes.add (temp); 

} 


* Puts the relation's data into a vector of vectors. 

private void initiateData() throws SQLException{ 
data = new Vector (); // vector of records 
Vector oneRow; // a vector of one record 

int numberOfColumns = attributes. size(); 

ResultSet temp = owner.getQueryResultSet(); 
while (temp.nextO) { 

oneRow = new Vector(); 

// insert the record data into a record vector 
for (int i = 1; i <= numberOfColumns; i++) { 
oneRow.addElement(temp.getString(i)); 

} 

// insert the record vector into data vector 
data.addElement(oneRow); 

} 

} 
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/* PROTECTED METHODS */ 

!** 

* ©return the date of the query execution (Date object) 
**/ 

protected Date getTimeStamp () { 
return tStamp; 

} 


/** 

* Sets the relation name 

* @param tableName the name of the relation (String) 

**/ 

protected void setTableName (String tableName) { 
name = tableName; 

} 


* Synchronizes the data with the database by calling the 'initiateData()' 

* method and resets the time stamp 

protected void updateRelationData () throws SQLException{ 
data = null; 

initiateDataO; // Re-initiates the relation data 
tStamp = new Date(); 

} 


32. Test.Java 

package ThesisGUI; 

* creates a MainTest class and shows it. 

* AUTHOR : BA & IS 

**/ 

public class test 

{ 

public static MainTest window = new MainTest(); 
public static void main(String args[]) 

{ 

window.showO; 

} 

} 
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33. UserOperatonJava 


package ThesisGUI; 

import java.awt.*; 

import javax.swing.*; 

import java.util.*; 

import com.borlandjbcl.control.*; 

import java.awt.event.*; 

* This class is used to display previously created user defined operators. 

* It allows user to use these operators as normal operators. 

* AUTHOR: IS & BA 

**! 

public class UserOperator extends JFrame { 


JTextField txtNoOfRelation 

= new JTextFieldO; 

JTextField txtNoOfCondition 

= new JTextFieldO; 

JTextField txtNoOfAttribute 

= new JTextFieldO; 

JTextField txtUserName 

= new JTextFieldO; 

JComboBox comboOperators 

= new JComboBoxO; 

JButton buttonAdd 

= new JButton("Add"); 

JButton buttonOK 

= new JButton("Ok"); 

JButton buttonCancel 

= new JButtonC'Cancel"); 

JButton buttonProceed 

= new JButtonC'Proceed =>"); 

JLabel IblOpName 

= new JLabelO; 

JLabel IblRelation 

= new JLabelO; 

JLabel IblCondition 

= new JLabelO; 

JLabel IblAttribute 

= new JLabelO; 

JTextArea txtAreaOperators 

= new JTextAreaO; 

int noOfRelation; 


int noOfCondition; 


int noOfAttribute; 


int noOfOperators; 


int x; 


int y; 


Vector operators; 


Vector queries; 


String query; 



/* CONSTRUCTOR */ 

/** 

* Default constractor 
**! 
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public UserOperatorQ { 
try { 

this.x =100; 
this.y = 100; 
jblnitO; 

} 

catch(Exception e) { 
e.printStackTraceO; 

} 

} 

/♦ CONSTRUCTOR */ 

/** 

* Constructor 

* ©parameters X and Y (integer) coordinates of the operator 

public UserOperator(int x, int y) { 
try { 

this.x = x; 
this.y = y; 

jblnitO; 

} 

catch(Exception e) { 
e.printS tackT race(); 

} 

} 

/* INITIATE METHOD */ 

/** 

* The initiation 

* creates the frame for user to enter the operator data, and adds 

* buttons, labels, text area and combo boxes. 

private void jbhiit() throws Exception { 
this.setSize (490,240); 
this.setTitle ("User Defined Operator"); 

IblOpName.setText ("Name"); 

IblRelation.setText ("# Relation"); 

IblCondition.setText ("# Condition"); 

IblAttribute.setText ("# Attribute"); 

IblOpName.setBounds (new Rectangle(12,15,95,28)); 
lblRelation.setBounds (new Rectangle(12,50, 95,28)); 

IblCondition-setBounds (new Rectangle(12, 86,95,28)); 
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IblAttribute.setBounds (new Rectangle(12,121,95,28)); 

buttonOK.setBounds (new Rectangle(308,169,72,19)); 

buttonAdd-setBounds (new Rectangle(369,50,90,19)); 

buttonCancel.setBounds (new Rectangle(383,169,78,19)); 


txtNoOfRelation.setNextFocusableComponent(txtNoOfCondition); 
txtNoOfRelation.setBounds (new Rectangle(105,48, 36,29)); 
txtNoOfCondition.setNextFocusableComponent(txtNoOfAttribute); 
txtNoOfCondition.setBounds (new Rectangle(105,84, 36,29)); 

txtNoOfAttribute.setNextFocusableComponent(buttonProceed); 
txtNoOfAttribute.setBounds (new Rectangle(105,120,36,29)); 

txtUserNanie.setNextFocusableComponent(txtNoOfRelation); 
txtUserName.setBounds (new Rectangle(105,12, 84,28)); 

comboOperators.setNextFocusableComponent(buttonAdd); 
comboOperators.setBounds (new Rectangle(310,18, 156,28)); 

buttonProceed.setNextFocusableComponent(comboOperators); 
buttonProceed.setBounds (new Rectangle(170,75, 110, 19)); 

txtAreaOperators.setBounds (new Rectangle(313,73, 148,91)); 


comboOperators.addItem 

comboOperators.addltem 

comboOperators.addItem 

comboOperators.addltem 

comboOperators.addItem 

comboOperators.addltem 

comboOperators.addltem 

comboOperators.addltem 

comboOperators.addltem 

comboOperators.addltem 

comboOperators.addltem 

comboOperators.addltem 


("Select"); 

("Join"); 

("Project"); 

("Intersect"); 

("Diff); 

("Union"); 

("GroupCnt"); 

("Eqjoin"); 

("GrpMin"); 

("GrpMax"); 

("GipAvg"); 

("GrpAllSat"); 


buttonOK.setEnabled (false); 

buttonAdd.setEnabled (false); 

buttonAdd.setNextFocusableComponent(comboOperators); 
buttonAdd.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
buttonAdd_actionPerformed(e); 

}}); 


buttonOK.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
buttonOK_actionPerformed(e); 

}}); 


313 



buttonCancel.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
buttonCancel_actionPeiformed(e); 

)}); 

buttonProceed.addActionListener(new java.awt.event.ActionListener() { 
public void actionPerformed(ActionEvent e) { 
buttonProceed_actionPerformed(e); 

)}); 

this.getContentPane().setLayout(null); 

txtUserName.requestFocusO; 

this.getContentPane().add(txtUserName, null); 
this.getContentPane().add(txtNoOfCondition, null); 
this.getContentPane().add(txtNoOfAttribute, null); 
this.getContentPane0.add(txtNoOfRelation, null); 
this.getContentPane().add(lblCondition, null); 
this.getContentPane().add(lblRelation, null); 
this.getContentPane().add(lblOpName, null); 
this.getContentPane().add(comboOperators, null); 
this.getContentPane().add(lblAttribute, null); 
this.getContentPane().add(button Add, null); 
this.getContentPane().add(txtAreaOperators, null); 
this.getContentPane().add(buttonProceed, null); 
this.getContentPane().add(buttonCancel, null); 
this.getContentPane().add(buttonOK, null); 

noOfOperators = 0; 

operators = new VectorQ; 

queries = new Vector(); 

show(true); 

} 


* This function is used to select operators which will be used as a part 

* of user defined operator. Once the operator selected user presses add 

* button to create it. 

**/ 

void buttonAdd_actionPerformed(ActionEvent e) { 
txtAreaOperators.append(comboOperators.getSelectedItem()+ "\n"); 
operators.addElement(comboOperators.getSelectedItem()); 
test.window.designOps.addElement("Op"+operators.size0); 
processOperators((String)comboOperators.getSelectedIteni0); 

} 
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!** 

* This function cancels all new operator creating process. 
**/ 

void buttonCancel_actionPerformed(ActionEvent e) { 
this.disposeO; 

test.window.setDesign(false); 

} 


/** 

* After the operator completely created. User presses this button to save it 

* and to leave this screen. 

**! 

void buttonOK_actionPerfonned(ActionEvent e) { 
processQueriesO; 

saveConfig deneme = new saveConfig(x,y, noOfRelation,noOfCondition, 
noOfAttribute, query, 
txtUserName.getTextO); 

this.disposeO; 

test.window.setDesign(false); 

} 

!** 

* When the operator is selected to be used as a part of user defined operator 

* the operator is created here. 

**! 

private void processOperators(String newOp){ 
if (newOp.equalsIgnoreCaseC'select")) { 

OperatorSelect newSelect = new OperatorSelect((String)test. window. 

designOps.lastElementO); 

} 

else if (newOp.equalsIgnoreCase("project")){ 

OperatorProject newProject = new OperatorProject((String)test. window. 

desi gnOps .lastElementQ); 

} 

else if (newOp.equalsIgnoreCase("join")){ 

OperatorJoin newJoin = new C)peratorJoin((String)test. window. 

designOps.lastElementO); 

} 

else if (newOp.equalsIgnoreCase("union")){ 

OperatorUnion newUnion = new OperatorUnion((String)test. window. 

designOps.lastElementO); 

} 

else if (newOp.equalsIgnoreCase("intersect")){ 

Operatorintersect newintersect = new OperatorIntersect((String)test. 

window.designOps. 
lastElementO); 
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} 

else if (newOp.equalsIgnoreCase("diff')){ 

OperatorDiff newDiff = new OperatorDiff((String)test.window. 

designOps .lastElementQ); 

} 

else if (newOp.equalsIgnoreCase("eqjoin")){ 

OperatorEqjoin newEqjoin = new OperatorEqjoin((String)test.window. 

designOps.lastElementO); 

} 

else if (newOp.equalsIgnoreCase("groupcnt")){ 

OperatorGroupCnt newGrpCnt = new OperatorGroupCnt 
^ ((String)test.window.designC)ps.lastElement()); 

else if (newOp.equalsIgnoreCase("grpallsat")){ 

OperatorGrpAllSat newGrpAllSat = new OperatorGrpAllSat 
^ ((String)test.window. designOps.lastElementO); 

else if (newOp.equalsIgnoreCase("grpavg’')){ 

OperatorGipAvg newGrpAvg = new OperatorGrpAvg((String)test. window. 

^ designOps.lastElementO); 

else if (newOp.equalsIgnoreCase("grpmax")){ 

OperatorGrpMax newGrpMax = new OperatorGrpMax((String)test.window. 

designOps.lastElementO); 

else if (newOp.equalsIgnoreCase("grpniin")){ 

OperatorGipMin newGipMin = new OperatorGrpMin((String)test. window. 

designOps.lastElementO); 

} 

void buttonProceed_actionPerformed(ActionEvent e) { 
test.window.designRelation.removeAllElementsO; 
test.window.designCondition.removeAllElementsO; 
test.window.designAttribute.removeAllElementsO; 
test.window.designOps.removeAllElementsO; 

noOfRelation = Liteger.parselntftxtNoOfRelation.getTextO); 

noOfCondition = Integer.parselnt(txtNoOfCondition.getTextO); 

noOfAttribute = Integer.parseInt(txtNoOfAttribute.getTextO); 

for (int relindex = 1; rellndex <= noOfRelation; relIndex-H-){ 

^test.window.designRelation.addElement("Rel"+relIndex); 

for (int conindex = 1; conindex <= noOfCondition; conIndex-H-){ 
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test.window.designCondition.addElement("Con"+conIndex); 

} 

for (int attindex = 1; attindex <= noOfAttribute; attIndex++){ 
test.window.designAttribute.addElement("Att"+attIndex); 

} 

buttonAdd.setEnabled(true); 

buttonOK.setEnabled(true); 

} 


* This function combines all the operators queries to produce the new operators 

* query. 

private void processQueries(){ 

String currentQuery = (String)test.window.designQueries.lastElement(); 
query = checkQuery (currentQuery); 

System.out.println(query); 

} 


* Query of the each operator is analyzed here and the connections 

* between the operators established. 

**/ 

private String checkQuery(String queryCheck){ 

String lastQuery = 

StringTokenizer queryTokenize = new StringTokenizer(queryCheck," ",true); 
String tryQueiy; 

String queryPart; 
int queryindex; 

while (queryTokenize.hasMoreTokens()) { 
tryQuery = (String)queryTokenize.nextToken(); 
queryindex = isOperator(tryQuery); 
if (queryindex > -1){ 

queryPart = checkQuery((String)test.window.designQueries.elementAt 
(queryindex)); 

lastQuery = lastQuery +"(" + queryPart + ")"; 

} 

else{ 

lastQuery = lastQuery + tryQuery; 

} 

} 

return lastQuery; 

} 
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* This function is used to identify the item if it is an operator or not. 

**/ 

private int isOperator(String op){ 

for (int ophidex=0; opindex < test.window.designOps.size();opIndex-H-){ 
if (op.equalsIgnoreCase 

((String)test.window.designOps.elementAt(opIndex))){ 
return opindex; 

} 

} 

return -1; 


} 


APPENDED-B 


EXAMPLE DATABASE 

Through out this thesis all the query examples are matched with the relational 
schema database, which is called the STUDENT database. 

RELATIONS 


Course: 
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